MySQL 模糊查询和分组查询

模糊查询:LIKE

常用的通配字符串:“%”,“_”

  1. 通配符 %:通配多个字符;表示0~n个任意字符
  2. 通配符 _ : 通配单个字符串

语法规则:

SELECT  字段名  FROM  表名  WHERE  字段名  LIKE  "匹配内容"

注释:

  1. 这里的like是“像…”的意思

  2. 若需要表示两个字符串的匹配,则需要使用两个_通配符

  3. 两个许多时候配合使用,可以产生多种组合结果

注意:这些通配符只有char,varchar和text类型才能使用like运算符和通配符

分组查询:GROUP BY

语法格式:

单列分组查询

SELECT 字段1,字段2  FROM 表名  GROUP BY  字段名

多列分组查询

SELECT 字段1,字段2  FROM 表名  GROUP BY  字段1,字段2

注释:

使用GROUP BY 关键字后,在SELECT语句的字段部分可以指定的列是有限的,仅允许以下几项:

  1. 被分组的列
  2. 为每个分组返回一个值的表达式,例如聚合函数计算出的列

Having子句—分组查询的条件筛选

语法格式:

SELECT 字段1,字段2  FROM 表名  GROUP BY  字段1,字段2  HAVING 条件子句

作用:过滤分组

注释:

在查询语句中,where,group by,having和聚合函数的执行次序如下:

  1. 首先执行where子句从数据库中筛选出需要的数据,
  2. 然后通过group by子句将筛选后的数据进行分组,聚合函数进行统计运算
  3. 最后,having子句筛选掉那些分组后不符合要求的数据行

顺序:where—>group by —>having

注意:

HAVING 必须和GROUP BY一起使用

WHERE和HAVING的对比:

  1. WHERE 可以直接使用表中的字段作为筛选条件,但不能使用分组中的计算函数作为筛选条件

  2. HAVING 在 GROUP BY 之 后,可以把分组计算的函数和分组字段作为筛选条件,对分组的结果集进行筛选;WHERE排除的记录不再包括在分组中

  3. 如果需要通过连接从关联表中获取需要的数据, WHERE 是先筛选后连接,而 HAVING 是先连接后筛选

优点缺点
WHERE先筛选数据再关联,执行效率高 不能使用分组中的计算函数进行筛选
HAVING可以使用分组中的计算函数 在最后的结果集中进行筛选,执行效率较低

关键字的顺序(SQL的书写)

SELECT . . . FROM . . . WHERE . . . GROUP BY . . . HAVING . . . ORDER BY . . . LIMIT . . .

SELECT 语句的执行顺序(机器执行)

FROM ->WHERE -> GROUP BY -> HAVING -> SELECT 的字段 -> DISTINCT -> ORDER BY-> LIMIT

聚合函数

聚合函数作用注释
avg() 平均值 可以对数值型数据使用
count() 总记录数返回表中记录总数,适用于任意数据类型
max() 最大值 可以对任意数据类型的数据使用
min() 最小值 可以对任意数据类型的数据使用
sum() 求和 可以对数值型数据使用

注释:

  1. 聚合函数是一种特殊的函数,基本功能是基于列进行计算,并返回单个值
  2. 聚合函数在计算过程中是忽略空值的,它常与select鱼鱼的group by子句一同使用
  3. 聚合函数是针对结果集中的数据进行计算的
  4. 聚合函数一定使用在查询中,作为一个列出现,这个列也是计算列,在数据表中不存在这一列,因此一般来说要起一个别名

count()

  1. count(*):计算数据表或查询结果集的总数行,不管某一列或多列是否为空

  2. count(字段名):计算查询结果中指定字段的总行数,计算时将会忽略该列为空的行

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值