这是一张搜索的关键字表,我需要的是 :sql 数据去重并且保留最新的一条,按时间排序 。
之前用 distinct 和 group by可以去重 但是数据不是按最新的排序。
😢distinct 和 group by实现
SELECT DISTINCT key_word, id
FROM tb_history
GROUP BY key_word
order by create_time desc
limit 10
结果是去重后的十条,但不是按时间排序
😁此种方式实现
SELECT * FROM tb_history th
where not exists
(
select 1 from tb_history
where key_word = th.key_word
and create_time > th.create_time
)
ORDER BY create_time desc
limit 10
个人记录一下。对数据库没很好的进行研究,如有不妥,欢迎指出,谢谢
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。