image.png
这是一张搜索的关键字表,我需要的是 :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
个人记录一下。对数据库没很好的进行研究,如有不妥,欢迎指出,谢谢