1. SELECT ...
例 :
2. SELECT ... FROM ...
(1). SELECT ... : 标识选择哪些列.
(2). FROM ... : 标识从哪个表中选取.
(3). *通配符 : 选择表中全部列.
例 :
3.列的别名
(1). 空一格.
(2). 在列和别名间加入关键字AS.
(3). 别名可以使用双引号,以便于在别名中包含空格或特殊的字符并区分大小写.
4. 去除重复行
使用DISTINCT关键字.
本来有107条记录,去除掉重复的firstname后,剩余91条记录.
SELECT DISTINCT first_name, last_name
FROM employees;
将删除该表中first_name, last_name都相同的记录.
5.空值参加运算
所有运算符或列值遇到null,其运算结构都为null.
在MySQL中,空值并不等同于空字符串.一个空字符串的长度为0,而一个空值的长度为空.在MySQL中,空值是占用空间的.
IFNULL(expression, value_if_null) : 如果expression是null,那么该空值将被value_if_null指定值替代.
6. 着重号
# 存在有这么一个表order SELECT * FROM order; # 将会报错, 大小写不敏感, order被视作ORDER关键字, 所以会报错 # 加上着重号引起来即可. SELECT * FROM `order`; # 正确的写法
7.查询常数
- SELECT 查询还可以对常数进行查询。对的,就是在 SELECT 查询结果中增加一列固定的常数列。这列的取值是我们指定的,而不是从数据表中动态取出的。
- 你可能会问为什么我们还要对常数进行查询呢?
- SQL 中的 SELECT 语法的确提供了这个功能,一般来说我们只从一个表中查询数据,通常不需要增加一个固定的常数列,但如果我们想整合不同的数据源,用常数列作为这个表的标记,就需要查询常数。
- 比如说,我们想对 employees 数据表中的员工姓名进行查询,同时增加一列字段corporation,这个字段固定值为“尚硅谷”,可以这样写:
8.显示表结构
我们可以使用DSECRIBE/DESC 表名
来显示表结构.
例 :
注 :
其中,各个字段的含义分别解释如下:
- Field:表示字段名称。
- Type:表示字段类型,这里 barcode、goodsname 是文本型的,price 是整数类型的。
- Null:表示该列是否可以存储NULL值。
- Key:表示该列是否已编制索引。PRI表示该列是表主键的一部分;UNI表示该列是UNIQUE索引的一部分;MUL表示在列中某个给定值允许出现多次。
- Default:表示该列是否有默认值,如果有,那么值是多少。Extra:表示可以获取的与给定列有关的附加信息,例如AUTO_INCREMENT等。
9.过滤数据(WHERE)
我们可以使用WHERE子句过滤不满足条件的行.WHERE子句紧跟FROM子句.
例 :