排序

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;

举例

mysql int类型多字段做排序 desc无效_数据


执行:

SELECT name, COUNT(*) FROM   employee_tbl GROUP BY name;

得到结果:

mysql int类型多字段做排序 desc无效_数据库_02


使用with rollup:

例如我们将以上的数据表按名字进行分组,再统计每个人登录的次数:

SELECT name, SUM(singin) as singin_count FROM  employee_tbl GROUP BY name WITH ROLLUP;

得到结果:其中记录 NULL 表示所有人的登录次数。

mysql int类型多字段做排序 desc无效_数据_03


注:

我们可以使用 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;

结果:

mysql int类型多字段做排序 desc无效_数据库_04

连接

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;

效果:取两个表的交集

mysql int类型多字段做排序 desc无效_database_05

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 字段值。

效果:读取左表所选取的所有字段数据,即使右表没有对应的字段数据。

mysql int类型多字段做排序 desc无效_mysql_06

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值处理的相关例子,便于复习和回顾。