MySQL——分组查询和分页查询

分组查询:group by
格式:

select 聚合函数(列名)from 表名[where条件] group by 列名 [having 条件];

面试会问:where子句和having子句的区别?

  • having子句:是对分组之后的结果进行筛选,即分组过后过滤数据,先分组,再过滤,having子句后面可以使用聚合函数。
  • where子句:是对查询结果进行过滤分组,将不符合where条件的行数据进行去掉,即分组之前进行数据的过滤,先过滤,再分组,where子句后面不能使用聚合函数。

DQL实现分页查询
如果数据库的数据量非常的大,百万级,千万级,因此我们查询的时候不建议一次性全部查询出来,这样可以使用分页查询提升程序性能和提高用户的体验。
MySQL的分页是使用limit实现的,限制的意思,所以limit的作用就是限制查询记录的条数,用来做分页查询。

select 列名 from [where 条件] limit a,b

a:表示开始的行数,从0开始计数,如果省略默认就是0,a=(当前页码-1)*b。
b:表示查询的行数,即每页显示的行数。

例如:分页查询

select * from student;
第一页
select * from student limit 0,2;
第二页
select * from student limit 2,2;
第三页
select * from student limit 4,2;

分页查询主要关注页码(第几页):pageNO,每页显示的记录条数pagesize;
分页查询公式:

select 列名 from 表名 [where 条件] limit(pageNo-1)*pagesize,pagesize
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值