Mysql中Group by子句结合count使用的效率问题
来源:互联网 发布:淘宝访客很高转化率低 编辑:程序博客网 时间:2024/06/05 10:34
articles
--------------
ID 标题 发布人 状态 是否推精
id title postby status isgood
要求取出发表文章最多的用户(优先按精华文章排)。
当然下面两种方法都不是最好方法,最好是将用户发表数量直接记录到用户表中去,但是有些时候数据库和程序已经设计好,要改动比较麻烦,那只有用以下方法了。
方法一
select postby,(select count(*) from articles where status=1 and postby=ar.postby) as art_num,(select count(*) from articles where status=1 and isgood=1 and postby=ar.postby) as goodart_num,title from articles as ar group by postby order by goodart_num desc,art_num desc limit 10
此方法中,group by子句在扫描表的时候,每一篇文章的都去执行了两次count,因此效率极低
方法二
select postby,sum(case when status=1 then 1 else 0 end) as art_num,sum(case when status=1 and isgood=1 then 1 else 0 end) as goodart_num,title from articles group by postby order by goodart_num desc,art_num desc limit 10
此方法,总共只需要执行一次表扫描,并且没有每次都count一下,而是用sum求一个总和,大大了减少了查询时间。效率会提高几百甚至几千倍
换一个思路有时候会豁然开朗!
解决了我的问题,转载过来啦先。
- Mysql中Group by子句结合count使用的效率问题
- MySql含有GROUP BY子句的查询中如何显示COUNT()为0的结果
- mysql中GROUP BY结合GROUP_CONCAT的使用 [转]
- mysql中GROUP BY结合GROUP_CONCAT的使用
- mysql中GROUP BY结合GROUP_CONCAT的使用
- mysql中GROUP BY结合GROUP_CONCAT的使用
- mysql中GROUP BY结合GROUP_CONCAT的使用
- mysql中GROUP BY结合GROUP_CONCAT的使用
- mysql中GROUP BY结合GROUP_CONCAT的使用
- mysql中GROUP BY结合GROUP_CONCAT的使用
- mysql中group by子句和聚合函数MAX(),MIN(),SUM(),AVG()等的使用
- Oracle中group by子句中rollup的使用
- Oracle中group by子句中cube的使用
- 含有GROUP BY子句的查询中如何显示COUNT()为0的结果
- 含有GROUP BY子句的查询中如何显示COUNT()为0的结果
- 使用GROUP BY子句的规则
- 关于group by子句使用的注意事项
- 解决mysql group by和count同时使用的bug
- Android中ListView应用
- iReport3.0 遇到的condition style问题
- ExtJS 4 表单
- ExtJS MVC架构讲解
- ExtJS 4 布局和容器
- Mysql中Group by子句结合count使用的效率问题
- UIFont 自适应大小剧中对齐 设置字体 与字体效果预览
- 后补个2012年的总结吧
- 用户空间命令与配置
- ExtJS 4 类系统(Class System)介绍
- 关于String的一些小知识
- IPHONE开发打开系统设置项,打开定位服务,打开Wifi等功能
- Feature CTP Walkthrough: Code Only for the Entity Framework
- android-----JNI中的log打印