mysql-数据筛选

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
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Z先生09

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值