文章详情页
mysql查询排序问题
浏览:259日期:2022-06-21 08:05:36
问题描述
hi ,guys.
问题是这样的,我有一张comment表,存储了所有用户的评论。
其中,pid代表该评论的父评论id。我想要获取pid为0的评论,按照它的子评论(评论的回复)的从大到小排列。
db使用了mysql,我不知该怎么写这个SQL。你能帮我么?
谢~~la
问题解答
回答1:不知道理解的对不对,查询并排序:select * from comment where pid = 0 order by (子评论回复字段 )desc
回答2:SELECT p.* FROM comment p LEFT JOIN comment c ON p.id = c.pid AND p.pid = 0 ORDER BY c.id desc
如果一个父评论下面有多个子评论,需要用到子查询
SELECT p.* FROM comment p LEFT JOIN (SELECT MAX(id) as id , pid FROM comment where pid != 0 GROUP BY pid) c ON p.id = c.pid AND p.pid = 0 ORDER BY c.id desc
不知道理解的对不对
相关文章:
1. java - web端百度网盘的一个操作为什么要分两次请求服务器, 有什么好处吗2. docker镜像push报错3. docker - 如何修改运行中容器的配置4. docker start -a dockername 老是卡住,什么情况?5. 正在使用electron和node.js做桌面应用,需要实时监听是否有网络连接,node或者electron是否可以做到6. docker安装后出现Cannot connect to the Docker daemon.7. node.js - express框架,设置浏览器从缓存中读取静态文件,只有js从缓存中读取了,css还有一些图片为何没有从缓存中读取?8. vim - docker中新的ubuntu12.04镜像,运行vi提示,找不到命名.9. java - 如何点击按钮,重新运行(我是初学者)?10. jquery - js向两边展开
排行榜

网公网安备