mysql – 有条件地GROUP BY不同的列
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql – 有条件地GROUP BY不同的列,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1380字,纯文字阅读大概需要2分钟。
内容图文
![mysql – 有条件地GROUP BY不同的列](/upload/InfoBanner/zyjiaocheng/893/16bf3d9162874e119cd4768c80403283.jpg)
我想显示聊天消息列表.
为此,我有一个SELECT语句:
SELECT id, `from`, sent, message, recd FROM chat
WHERE id IN(
SELECT MAX(id) FROM chat
WHERE `to` = ? GROUP BY `from`
)
ORDER BY id DESC
问题是,我想有条件地选择= maria和from = maria的消息.
也就是说,如果要=玛丽亚我想分组来自,如果来自=玛丽亚,我想分组到.
如何动态更改此GROUP BY?
解决方法:
我认为所有提议的查询都很好 – 这意味着他们将返回预期的结果(每个不同的用户已经发送或接收来自’maria’的消息) – 但效率可能不是很好. MySQL不会使用WHERE列IN(复杂子查询)优化良好查询.优化器在5.6和5.7版本中有一些改进,但仍然可以帮助它获得更好的计划和使用索引.
你的问题和评论令人困惑.不清楚每个不同用户(收件人,发件人)或结果中只有一行是否需要一行.
如果你想要第二个,我的建议是在(to)和(from)上添加两个索引(如果你还没有)(我假设表是InnoDB而主键是(id)那么(to)和(from)索引等价于(to,id)和(from,id)索引,这些是查询真正需要的.)
并使用以下查询:
( SELECT id, `from`, `to`, sent, message, recd
FROM chat
WHERE `to` = ?
ORDER BY id DESC
LIMIT 1
)
UNION ALL
( SELECT id, `from`, `to`, sent, message, recd
FROM chat
WHERE `from` = ?
ORDER BY id DESC
LIMIT 1
)
ORDER BY id DESC
LIMIT 1 ;
这相当于(谢谢@Thorsten Kettner):
SELECT id, `from`, `to`, sent, message, recd
FROM chat
WHERE ? IN (`to`, `from`)
ORDER BY id DESC
LIMIT 1 ;
也尝试这个最后一个版本,如果它同样有效,则更喜欢它.除非效率不高,否则没有理由使查询复杂化.对于给定的索引,最后一个版本将经常使用它们和index merge union算法.
内容总结
以上是互联网集市为您收集整理的mysql – 有条件地GROUP BY不同的列全部内容,希望文章能够帮你解决mysql – 有条件地GROUP BY不同的列所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。