注:SQL语句中的关键字和函数大小写不敏感。
SQL语句执行顺序:
from-->where-->group by -->having --- >select --> order
第一步:from语句,选择要操作的表。
第二步:where语句,在from后的表中设置筛选条件,筛选出符合条件的记录。
第三步:group by语句,把筛选出的记录进行分组。
第四步:having语句,设置条件筛选分组后的数据。
第五步:select语句,选取经过上述流程后的结果集。
第六步:order by语句:将select后的结果集按照顺序展示出来。
注意:
掌握SQL语句执行流程非常重要,是理解并写好SQL语句的前提,根据实际业务逻辑要执行的数据库操作对应到SQL语句的执行流程能够帮助我们快速写出相应功能的标准SQL语句。
select:
- 作用:选取结果集。
- 位置:位于SQL语句开始。
from:
- 作用:from后跟要操作的数据表。
- 数据表形式:单个表、多个并列的表、多个进行join的表。
- 位置:位于select之后。
where:
- 作用:设置条件,过滤记录。
- 位置:位于from之后。
where语句中的运算符:
运算符 | 描述 |
= | 等于 |
<> | 不等于。注:一些版本中也可为!=。 |
> | 大于 |
< | 小于 |
>= | 大于等于 |
<= | 小于 |
BETWEEN | 在某个范围内 |
LIKE | 匹配某种模式 |
IN | 在多个可能值之中 |
where语句中的条件类型:
逻辑运算:
- AND:且,同时满足多个条件的值。
- OR:或,满足多个条件中至少一个即可。
特殊条件:
-
IS NULL:空值判断。
- BETWEEN:在范围之间的值。
- IN:在多个可能值之中。
- LIKE:模糊查询。
group by:
- 作用:用于结合结合聚合函数,感觉一个列或多个列对结果集进行分组。
- 位置:一般位于where后或者SQL语句末尾位置。
having:
- 作用:筛选分组后的各组数据,一般和聚合函数结合使用。
- 位置:一般位于SQL语句末尾。
常用聚合函数:
函数 | 作用 |
sum(列名) | 求和 |
max(列名) | 最大值 |
min(列名) | 最小值 |
avg(列名) | 平均值 |
first(列名) | 第一条记录 |
last(列名) | 最后一条记录 |
count(列名) | 统计记录数 注:count(*)为统计所有记录数 |
order by:
- 作用:用于对结果集按照一个或者多个列进行排序。
- 位置:一般位于SQL语句末尾。
排序:
- 默认按照升序对记录进行排序,如果按照降序对记录进行排序,需加DESC关键字。
- order by多列时,先按照第一个column_name排序,再按照第二个column_name排序。
排序实例:
order by A # A升序排列
order by A desc,B # A 降序(优先),B 升序排列
order by A ,B desc # A 升序(优先),B 降序排列
where和having区别:
- where在group by前, having在group by 之后。
- where中不能使用聚合函数,having中可以使用聚合函数。原因:因为聚合函数是针对结果集进行的,但where是在查询结果集之前进行,故where中不能使用聚合函数;having是针对结果集做筛选的,故一般把聚合函数放在having中。