mysql的数据筛选
去掉重复值查询(DISTINCT)
SELECT DISTINCT col1, col2 FROM 表名
限制返回行数(LIMIT)
在查询中,经常要返回前几条或者中间某几行数据时,用到limit
select * from table_name limit [offset,] rows
---------------说明---------------
offset:指定第一个返回记录行的偏移量(即从哪一行开始返回),注意:初始行的偏移量为0,可以为空,默认为0
rows:返回具体行数
在查询中,经常要返回前几条或者中间某几行数据时,用到limit
排序
-
ASC(升序)
SELECT * FROM 表名ORDER BY 列名 ASC
-
DESC(降序)
SELECT * FROM 表名ORDER BY 列名 DESC
分组(GROUP BY)
分组就是把具有相同的数据值的行放在同一组中
SELECT SEX, COUNT(SEX) AS num FROM 表名GROUP BY SEX
连接
内连接(INNER JOIN)
内连接会取出连接表中匹配到的数据,匹配不到的不保留
SELECT A.value, B.value FROM A表名 AS A INNER JOIN B表名 AS BON A.key = B.key
外连接
左连接(LEFT JOIN)
取出连接表中匹配到的数据,匹配不到的也会保留,其值为NULL
SELECT A.value, B.value FROM A表名 AS A LEFT JOIN B表名 AS BON A.key = B.key
右连接(RIGHT JOIN)
SELECT A.value, B.value FROM A表名 AS A RIGHT JOIN B表名 AS BON A.key = B.key
组合查询
-
UNION。UNION 用于合并两个或多个 SELECT 语句的结果集,并消去表中任何重复行
select A列名, B列名 from A表名 UNION select A列名, B列名 from B表名
-
UNION ALL。UNION ALL用于合并两个或多个 SELECT 语句的结果集,包含所有重复的行
select A列名, B列名 from A表名UNION ALLselect A列名, B列名 from B表名
子查询
子查询中只能返回一个字段的数据
SELECT * FROM A表名 WHERE A列名 IN (SELECT B列名 FROM B表名)
条件查询(WHERE)
符号
=、<、>、!=、<=、>=、> all、> any、()=
select * from 表名 where xx = 1
select * from 表名 where xx > all (select xx from B表名)
select * from 表名 where (A列名,B列名) = (select A列名,B列名 from 表名 where 条件)
BETWEEN
筛选某个属性或某个表达式结果的某个范围内的数据
select * from 表名 where xx between 10 and 50
IS NULL
SELECT * FROM 表名 WHERE 列名 IS NULL
连接符
AND、OR。用于连接多个过滤条件
IN
IN操作符用于匹配一组值
select * from 表名 where xx in(1, 9, 13)
NOT
NOT用于否定一个条件
select * from 表名 where not like 'aa%'
select * from 表名 where not in (1, 2,5)
正则匹配
聚合(Having)
WHERE 关键字无法与聚合函数一起使用,HAVING 子句可以让我们筛选分组后的各组数据,having后的判断字段必须是聚合函数返回的结果
SELECT SEX, SUM(SEX) as num FROM 表名 WHERE age < 30 GROUP BY SEX HAVING num > 10
exists
用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回true或false
视图
视图是虚拟的表,本身不包含数据,也就不能对其进行索引操作
-
优点
- 简化查询,比如复杂的连接
- 控制数据的访问
- 数据库视图允许计算列。如:价格列 = 单价 * 数量
- 更改数据格式和表示
-
缺点
- 查询数据可能会很慢
- 依赖其它的表或视图
-
示例
CREATE VIEW 视图名 ASSELECT Concat(A列名, B列名) AS AB列名, C列名 FROM 表名WHERE sex = 1
其它
存储过程
存储过程可以看成是对一系列 SQL 操作的批处理
游标
在存储过程中使用游标可以对一个结果集进行移动遍历
触发器
监视某种情况,并进行某种操作,它的执行并不是程序调用,也不是手工启动,而是由事件来触发
加锁查询
for upate
select * from 表名 for update