mysql - SQL分组排序、随机问题?
问题描述
有一个帖子的回复表,posts(id , tid , subject ,message ,dateline),其中:id为自动增长字段,tid为该回复的主体帖子的id(外键关联),subject为回复标题,message为回复内容,dateline为回复时间,用UNIX时间戳表示。请写SQL,
选出按时间排序的前十个来自不同主题的最新回复;
随机选一条回复记录;
问题解答
回答1:目测1楼第一句不对,没有保证不同的主题,我是这么写的:
select * from posts p where p.dateline = (select max(dateline) from posts where tid = p.tid) order by dateline desc limit 10;
其实dateline和id应该顺序是一致的,可以考虑换成id,id上主键应该效率更高:
select * from posts p where p.id = (select max(id) from posts where tid = p.tid) order by id desc limit 10;
第2句个人觉得最好还是不用ORDER BY RAND(),数据量稍微多一点就会效率低下,因为这样写可以会导致多次扫描,这样写可能会好一点:
SELECT * FROM posts WHERE id >= ((SELECT MAX(id) FROM posts)-(SELECT MIN(id) FROM posts)) * RAND() + (SELECT MIN(id) FROM posts) LIMIT 1;回答2:
试试看,如果表数据过大不建议使用ORDER BY RAND(),你先试试这两句SQL行不行。希望对你有帮助.
SELET `id`,`tid`,`subject`,`message`,`dateline` FROM `posts` WHERE `tid`=NULL ORDER BY `tid`,`dateline`SELET `id`,`tid`,`subject`,`message`,`dateline` FROM `posts` WHERE `tid`=!NULL ORDER BY RAND() LIMIT 1回答3:
楼上第一条回答目测不对吧,以下个人见解,欢迎点评指教
select t2.* from (select tid,max(dateline) maxDateline from posts group by tid order by maxDateline desc limit 10)t1 inner join posts t2 on t1.tid=t2.tid and t1.maxDateline=t2.dateline
相关文章:
1. javascript - easyui textbox绑定onchange事件不能获取最新的文本框的值2. html - css 文件内,有的样式没调用, 有没有工具删除这部分没调用的内容?3. css - chrome浏览器input记录上次cookie信息后,有个黄色背景~如何去除!4. java - 图片上传后,立即访问出现404,重新部署项目后正常可以访问5. PHP类中的$this6. javascript - 请教如何获取百度贴吧新增的两个加密参数7. javascript - Jquery click()事件的禁用8. html5 - h5写的app用的webview,用手机浏览器打开不显示?9. javascript - 为什么在谷歌控制台 输出1的时候,输出的1立马就不见了10. java - win10子系统设置环境变量
