好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

SQL-过滤和排序-LeetBook

WHERE col IS NULL

下表显示了 WHERE 子句可用的操作符

操作符 说明 = 等于 < 小于 > 大于 <>   != 不等于 <=   !> 小于等于 >=   !< 大于等于 BETWEEN 在两个值之间 is NULL 为NULL值

 

注: NULL 与 0、空字符串都不同 。

AND 和 OR 用于连接多个过滤条件 。 优先处理 AND ,当一个过滤表达式涉及到多个 AND 和 OR 时,可以使用 () 来决定优先级,使得优先级关系更清晰。

IN 操作符用于匹配一组值, 其后也可以接一个 SELECT 子句 ,从而匹配子查询得到的一组值。

NOT 操作符用于否定一个条件。

二、排序

SELECT * FROM mytable

ORDER BY col1 DESC, col2 ASC

注:

  ASC:升序(默认)

  DESC:降序

三、通配符

使用 Like 来进行通配符匹配,通配符也是用在过滤语句中,但它 只能用于文本字段 。

% 匹配 >=0 个任意字符;

_ 匹配 ==1 个任意字符;

[ ] 可以匹配集合内的字符,例如 [ab] 将匹配字符 a 或者 b。用脱字符 ^ 可以对其进行否定,也就是不匹配集合内的字符。

SELECT *

FROM mytable

WHERE col LIKE ‘[^AB]%‘     -- 不以 A 和 B 开头的任意文本

注:通配符位于开头处匹配会非常慢。

四、分组

把具有相同的数据值的行放在同一组中。

可以对同一分组数据使用汇总函数进行处理,例如求分组数据的平均值等。

指定的分组字段 除了能按该字段进行分组,也会自动按该字段进行排序 。

SELECT col, COUNT(*) AS num

FROM mytable

GROUP BY col

1. GROUP BY 自动按 分组字段 进行排序, ORDER BY 也可以按 汇总字段 来进行排序 。

SELECT col, COUNT(*) AS num

FROM mytable

GROUP BY col

ORDER BY num

2. WHERE 过滤 行 , HAVING 过滤 分组 ,行过滤应当 先于 分组过滤 。

SELECT col, COUNT(*) AS num

FROM mytable

WHERE col > 2

GROUP BY col

HAVING num >= 2

3.分组规定:

GROUP BY 子句出现在 WHERE 子句之后,ORDER BY 子句之前; 除了汇总字段外,SELECT 语句中的每一字段都必须在 GROUP BY 子句中给出; NULL 的行会单独分为一组; 大多数 SQL 实现不支持 GROUP BY 列具有可变长度的数据类型。

 

SQL-过滤和排序-LeetBook

标签:iter   字符串   均值   com   集合   line   分组   like   book   

查看更多关于SQL-过滤和排序-LeetBook的详细内容...

  阅读:25次