阿里云天池龙珠计划SQL训练营学习笔记https://tianchi.aliyun.com/specials/promotion/aicampsql
SELECT语句作为DML语言,在实际业务中应用广泛。其语法规则为,
--一般查询语句
SELECT <列名>,
FROM <表名>;
--条件查询语句
SELECT <列名>, ……
FROM <表名>
WHERE <条件表达式>;
--聚合、分组查询语句
SELECT 聚合函数
FROM <表名>
WHERE <条件表达式1>
GROUP BY <列名1>, <列名2>, <列名3>, ……
HAVING <条件表达式2>
ORDER BY <排序基准列1> DESC, <排序基准列2> ASC, ……
1 一般查询语句
“SELECT * ”表示查询全部记录;
“SELECT <列名> AS <别名>” 查询指定列,并起别名
- 星号(*)代表全部列的意思。
- SQL中可以随意使用换行符,不影响语句执行(但不可插入空行)。
- 设定汉语别名时需要使用双引号(")括起来。
- 在SELECT语句中使用DISTINCT可以删除重复行。
2 条件查询语句
通过WHERE语句进行条件筛选。
在WHERE语句中可以使用算数运算符+、-、*、/,比较运算符=、>、<、<>,逻辑运算符AND、OR、NOT。
在字符串判断或日期判断是,需使用双引号(")括起来。
特别指出,若要选取NULL记录,须使用WHERE <列名> IS NULL进行筛选。
使用WHERE <列名> IS NOT NULL,筛选非空记录。
同时,由于NULL的存在,逻辑运算在关系数据库中属于三值逻辑,见下表。
3 聚合查询
聚合函数有COUNT、SUM、AVG、MAX、MIN,
- COUNT:计算表中的记录数(行数)
- SUM:计算表中数值列中数据的合计值
- AVG:计算表中数值列中数据的平均值
- MAX:求出表中任意列中数据的最大值
- MIN:求出表中任意列中数据的最小值
- COUNT函数的结果根据参数的不同而不同。COUNT(*)会得到包含NULL的数据行数,而COUNT(<列名>)会得到NULL之外的数据行数。
- 聚合函数会将NULL排除在外。但COUNT(*)例外,并不会排除NULL。
- MAX/MIN函数几乎适用于所有数据类型的列。SUM/AVG函数只适用于数值类型的列。
- 想要计算值的种类时,可以在COUNT函数的参数中使用DISTINCT。
- 在聚合函数的参数中使用DISTINCT,可以删除重复数据。
4 分组查询
GROUP BY的子句书写顺序有严格要求,不按要求会导致SQL无法正常执行,目前出现过的子句书写****顺序为:
1**.**SELECT → 2. FROM → 3. WHERE → 4. GROUP BY
其中前三项用于筛选数据,GROUP BY对筛选出的数据进行处理。
在使用聚合函数及GROUP BY子句时,经常出现的错误有:
- 在聚合函数的SELECT子句中写了聚合健以外的列。使用COUNT等聚合函数时,SELECT子句中如果出现列名,只能是GROUP BY子句中指定的列名(也就是聚合键)。
- 在GROUP BY子句中使用列的别名。SELECT子句中可以通过AS来指定别名,但在GROUP BY中不能使用别名。因为在DBMS中 ,SELECT子句在GROUP BY子句后执行。
- 在WHERE中使用聚合函数。原因是聚合函数的使用前提是结果集已经确定,而WHERE还处于确定结果集的过程中,所以相互矛盾会引发错误。 如果想指定条件,可以在SELECT,HAVING以及ORDER BY子句中使用聚合函数。
因为SQL在使用 HAVING 子句时 SELECT 语句的执行****顺序为:
FROM → WHERE → GROUP BY → HAVING → SELECT → ORDER BY
其中SELECT的执行顺序在 GROUP BY 子句之后,ORDER BY 子句之前。
当在ORDER BY中使用别名时,已经知道了SELECT设置的别名存在,但是在GROUP BY中使用别名时还不知道别名的存在,所以在ORDER BY中可以使用别名,但是在GROUP BY中不能使用别名****。