排序
order by子句
用途:
用于设置字段的排序方式,然后返回搜索结果
语法
SELECT field1, field2,...fieldN FROM table_name1, table_name2...
ORDER BY field1 [ASC [DESC][默认 ASC]], [field2...] [ASC [DESC][默认 ASC]]
//asc:升序
//desc:降序
你可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
你可以设定多个字段来排序。
你可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。 默认情况下,它是按升序排列。
你可以添加 WHERE…LIKE 子句来设置条件。
举例:
select * from 表 order by 列名 asc/desc;
GROUP BY语句
用途:
根据一个或多个列对结果进行分组
在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。
语法:
SELECT column_name, function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name;
举例
执行:
SELECT name, COUNT(*) FROM employee_tbl GROUP BY name;
得到结果:
使用with rollup:
例如我们将以上的数据表按名字进行分组,再统计每个人登录的次数:
SELECT name, SUM(singin) as singin_count FROM employee_tbl GROUP BY name WITH ROLLUP;
得到结果:其中记录 NULL 表示所有人的登录次数。
注:
我们可以使用 coalesce 来设置一个可以取代 NUll 的名称,
coalesce 语法:
select coalesce(a,b,c);
参数说明:如果anull,则选择b;如果bnull,则选择c;如果a!=null,则选择a;如果a b c 都为null ,则返回为null(没意义)。
SELECT coalesce(name, '总数'), SUM(singin) as singin_count FROM employee_tbl GROUP BY name WITH ROLLUP;
结果:
连接
JOIN
用途:
在两个或多个表中查询数据
JOIN 按照功能大致分为如下三类:
INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
INNER JOIN
用途:
获取两个表中字段匹配关系的记录。
举例:
mysql> SELECT a.nowcoder_id, a.nowcoder_author, b.nowcoder_count
FROM nowcoder_tbl a INNER JOIN tcount_tbl b ON a.nowcoder_author = b.nowcoder_author;
等价于:
mysql> SELECT a.nowcoder_id, a.nowcoder_author, b.nowcoder_count
FROM nowcoder_tbl a,tcount_tbl b where a.nowcoder_author=b.nowcoder_author;
效果:取两个表的交集
LEFT JOIN
用途:
获取左表所有记录,即使右表没有对应匹配的记录。
举例:
mysql> SELECT a.nowcoder_id, a.nowcoder_author, b.nowcoder_count
FROM nowcoder_tbl a LEFT JOIN tcount_tbl b ON a.nowcoder_author = b.nowcoder_author;
以上实例中使用了 LEFT JOIN,该语句会读取左边的数据表 nowcoder_tbl 的所有选取的字段数据,即便在右侧表 tcount_tbl中 没有对应的 nowcoder_author 字段值。
效果:读取左表所选取的所有字段数据,即使右表没有对应的字段数据。
RIGHT JOIN
用途:
与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
举例:
mysql> SELECT a.nowcoder_id, a.nowcoder_author, b.nowcoder_count
FROM nowcoder_tbl a RIGHT JOIN tcount_tbl b ON a.nowcoder_author = b.nowcoder_author;
以上实例中使用了 RIGHT JOIN,该语句会读取右边的数据表 tcount_tbl 的所有选取的字段数据,即便在左侧表 nowcoder_tbl 中没有对应的nowcoder_author 字段值。
效果:读取右表所选取的所有字段数据,即使左表没有对应的字段数据。
NULL值处理
为什么要处理null?
因为在使用select或者where子句来读取表中数据时,若提供查询条件字段为NULL则可能导致命令无法工作。
为了处理这种情况,MySQL提供了三大运算符:
IS NULL: 当列的值是 NULL,此运算符返回 true。
IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。
<=>: 比较操作符(不同于=运算符),当比较的的两个值为 NULL 时返回 true。关于 NULL 的条件比较运算是比较特殊的。你不能使用 = NULL 或 != NULL 在列中查找 NULL 值 。
在 MySQL 中,NULL 值与任何其它值的比较(即使是 NULL)永远返回 false,即 NULL = NULL 返回false 。
MySQL 中处理 NULL 使用 IS NULL 和 IS NOT NULL 运算符。
举例
select * , columnName1+ifnull(columnName2,0) from tableName;
columnName1,columnName2 为 int 型,当 columnName2 中,有值为 null 时,columnName1+columnName2=null, ifnull(columnName2,0) 把 columnName2 中 null 值转为 0。
is null:
select * from nowcoder_test_tbl where nowcoder_count is null;
//查询所有nowcoder_count值为null的行
select * from nowcoder_test_tbl where nowcoder_count is not null;
//查询所有nowcoder_count值不为null的行
注意:
处理null时,=和!=不起作用,要采用is null和is not null。
总结:
本文介绍了对查询结果排序,组合的MySQL指令的用途和语法,介绍了NULL值处理的相关例子,便于复习和回顾。