北京SEO

mysql group by 排序问题一些自我理解

2019/10/10/17:35:15  阅读:1933  来源:谷歌SEO算法  标签: 搜索引擎

记得以前老师跟我讲sql中group by与order by 不能同时使用,使用时会有问题,后来我工作了发现他讲的是错误的,其实mysql group by 与排序是可使用的,只要我们稍加处理。

类如有一个 帖子的回复表,posts(id,tid,subject,message,dateline).

id为 自动增长字段,tid为该回复的主题帖子的id(外键关联),subject 为回复标题, message 为回复内容,dateline 为回复时间,用UNIX 时间戳表示.

现在要求 选出 前十个来自不同主题的最新回复,代码如下:

SELECT * FROM posts GROUP BY tid LIMIT 10

这样一个sql语句选出来的并非你想要的 最新的回复,而是最早的回复,实际上是某篇主题的第一条回复记录.

也就是说 GROUP BY 语句没有排序,那么怎么才能让 GROUP 按照 dateline 倒序排列呢?加上 order by 子句?

group by 后order by不准确问题,解决如下:

错误语句,代码如下:

select A.id, A.type, B.id, B.h1 from A,B where A.type=3 and A.id=B.id group by B.id order by A.id desc limit 10

正确语句,代码如下:

select A.id, A.type, B.id, B.h1 from A,B where A.type=3 and A.id=B.id group by B.id order by max(A.id) desc limit 10

最简单的,代码如下:

  1. SELECT*FROM(SELECT*FROMpostsORDERBYdatelineDESC)ASpGROUPBYtidORDERBYdatelineDESCLIMIT10--phpfensi.com

也有网友利用自连接实现的,这样的效率应该比上面的子查询效率高,不过,为了简单明了,就只用这样一种了,GROUP BY没有排序功能,可能是mysql弱智的地方,也许是我还没有发现.

广告内容

mysql group by 排序问题一些自我理解 mysql group by 排序问题一些自我理解 mysql group by 排序问题一些自我理解

相关阅读

热门评论

小明SEO博客 小明SEO博客

小明SEO博客,新时代SEO博客

总篇数171

精选文章

RMAN中catalog和nocatalog区别介绍 小技巧:为Linux下的文件分配多个权限 zimbra8.5.1安装第三方签名ssl证书的步骤 解决mysql不能远程连接数据库方法 windows服务器mysql增量备份批处理数据库 mysql中slow query log慢日志查询分析 JavaScript跨域问题总结 Linux下负载均衡软件LVS配置(VS/DR)教程 mysql中权限参数说明 MYSQL(错误1053)无法正常启动

SEO最新算法