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

Posted 名字真的很急用

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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

以上是关于MySQL——分组查询和分页查询的主要内容,如果未能解决你的问题,请参考以下文章

MySQL学习7:分组和分页

MySQL的limit用法和分页查询的性能分析及优化

MySQL从入门到精通高级篇(二十八)子查询优化,排序优化,GROUP BY优化和分页查询优化

MySQL从入门到精通高级篇(二十八)子查询优化,排序优化,GROUP BY优化和分页查询优化

Mysql SQL_CALC_FOUND_ROWS 和分页

MySQL——排序和分页