
一个 sql 咨询
问题:
如何编写 sql 查询,以确定哪些用户查看了特定文章,以及这些用户查看过的其他最常浏览的文章?
背景:
存在一张记录每个用户浏览的文章(含 id)的表格。需求如下:
计算每篇文章被哪些用户查看。找出这些用户浏览过的其他文章中最常浏览的几篇文章。按浏览次数降序排列结果。
解决方案:
方法 1:异步任务
对于大量数据,使用异步任务定时统计每个文章关联文章的浏览次数是一个更好的选择。这可以避免过度加载数据库。
方法 2:sql 查询
如果必须使用 sql 一次性解决所有问题,可以使用如下查询:
-- 页面访问日志表CREATE TABLE `read_log` ( `content_id` int, `uid` int);-- 每个页面的访问用户访问过的页面在这些用户下的访问次数统计SELECT l.content_id AS l_content_id, -- 每个需要统计的页面ID, -- l.uid_list l.uid_list AS '访问过 每个需要统计的页面ID 的用户组', t.content_id AS t_content_id, -- 访问过 每个需要统计的页面ID 的用户组 仿问过的需要统计pv的页面ID COUNT(t.uid) AS pvFROM read_log tJOIN ( SELECT content_id, GROUP_CONCAT(DISTINCT uid, '') AS uid_list FROM read_log GROUP BY content_id) lON FIND_IN_SET(t.uid, l.uid_list)GROUP BY l.content_id, t.content_idORDER BY l.content_id, pv DESC;
注意:如果需要在排名后只获取前 n 条数据,请使用额外的嵌套查询。
以上就是如何使用 SQL 查询找出哪些用户阅读了特定文章以及这些用户最常浏览的其它文章?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/52950.html
微信扫一扫
支付宝扫一扫