如何使用 SQL 查询找出哪些用户阅读了特定文章以及这些用户最常浏览的其它文章?

如何使用 sql 查询找出哪些用户阅读了特定文章以及这些用户最常浏览的其它文章?

一个 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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 07:09:02
下一篇 2025年11月9日 07:13:51

相关推荐

  • C++中内存对齐有什么作用 探讨对齐对性能和数据访问的影响

    内存对齐在c++++中至关重要,因为它直接影响程序的性能和稳定性。其核心目的是提升cpu访问效率并避免硬件异常。现代cpu以“块”为单位读取内存,未对齐的数据可能需要多次访问,降低速度,甚至导致arm等平台崩溃。编译器自动对齐结构体成员,尽管可能引入填充字节,但提升了访问速度。例如,struct e…

    2025年12月18日 好文分享
    000
  • priority_queue如何实现自定义优先级 比较函数与运算符重载实例

    在c++++中使用priority_queue时,若需自定义优先级排序,主要有两种方法:传入比较函数(或仿函数)和重载运算符。1. 使用仿函数方式更灵活,适合不同优先队列需要不同比较逻辑的场景,例如定义一个compare结构体重载operator()来实现小顶堆或根据结构体成员排序;2. 重载运算符…

    2025年12月18日 好文分享
    000
  • C++中restrict修饰指针有什么用?说明编译器优化提示

    restric++t关键字在c++中的核心作用是作为编译器优化提示,表明被修饰的指针是访问其指向内存的唯一方式。这使编译器能够进行更积极的优化,包括:1.循环向量化:允许编译器将循环操作向量化,提升并行计算效率;2.消除冗余加载/存储:假设通过restrict指针读取的数据不会被其他指针修改,从而减…

    2025年12月18日 好文分享
    000
  • 怎样使用STL实现自定义排序 灵活运用sort和priority_queue

    在c++++中,stl的sort()和priority_queue支持自定义排序规则。1. sort()函数通过传入比较函数或lambda表达式实现自定义排序,如按成绩从高到低排序学生结构体;2. priority_queue需提供比较器作为模板参数,如实现最小堆处理任务优先级;3. 仿函数适合复用…

    2025年12月18日 好文分享
    000
  • 如何优化结构体访问性能 CPU缓存友好型结构体设计原则

    优化结构体访问性能的核心在于提升cpu缓存利用率,具体方法包括:1. 利用空间局部性,将频繁一起访问的数据成员相邻存放;2. 合理调整结构体成员顺序和对齐方式,减少填充字节并提高缓存行使用效率;3. 根据访问模式选择aos或soa结构,匹配主要数据访问需求;4. 避免伪共享,通过填充、数据局部化、结…

    2025年12月18日 好文分享
    000
  • 结构体数组怎样定义和使用 批量处理结构体数据实例演示

    结构体数组是将多个结构体实例排列成集合的数据结构,它允许存储和管理具有多种属性的同类数据记录。1. 定义时需先声明结构体类型,再创建数组;2. 初始化可逐个赋值或在定义时指定初始值;3. 使用时通过索引访问结构体成员并进行批量处理;4. 与普通数组的区别在于每个元素是一个包含多种数据类型的结构体,而…

    2025年12月18日 好文分享
    000
  • C++函数对象是什么 重载operator()的可调用对象详解

    函数对象是c++++中通过重载operator()实现的可调用对象,其核心优势在于能够保持状态并结合数据与行为。1. 函数对象通过类的operator()重载实现调用行为,允许在多次调用间维护成员变量状态;2. 相较于普通函数和函数指针,函数对象能保存内部状态,适用于需上下文信息的场景如stl算法定…

    2025年12月18日 好文分享
    000
  • C++11的lambda表达式如何工作 匿名函数的捕获列表与使用场景

    lambda表达式是c++++11引入的一种简洁编写内联函数对象的机制,其本质是一个由编译器生成未命名类类型的可调用对象,该类重载了operator()。例如:auto f = [](int x) { return x * x; };创建了一个不捕获变量的lambda。捕获列表决定lambda如何访…

    2025年12月18日 好文分享
    000
  • C++的位域怎么定义 结构体中位字段的内存布局与使用

    c++++中的位域允许为结构体或联合体成员指定占用的比特位数,实现对内存的精细控制。1. 位域通过在成员声明后加冒号和位数实现,如unsigned int status : 3;。2. 常用类型为unsigned int、signed int和bool,其中unsigned int因避免符号位问题最…

    2025年12月18日 好文分享
    000
  • C++结构体与类有什么区别 解析内存布局与访问控制的差异

    c++++中结构体和类的主要区别在于默认访问权限和继承方式。1. 默认访问权限:结构体成员默认是public,而类成员默认是private;2. 继承方式:结构体默认public继承,类默认private继承。两者在内存布局上无本质差异,均受成员变量类型、顺序及内存对齐规则影响。选择结构体还是类取决…

    2025年12月18日 好文分享
    000
  • C++如何优化数据结构布局 提高缓存命中率的实践技巧

    在c++++开发中,优化数据结构布局能显著提高缓存命中率和程序性能。1. 减少结构体内部填充:通过按成员变量大小从大到小排列字段顺序、使用#pragma pack或alignas控制对齐方式,可减少填充字节并提升缓存利用率;2. 避免冷热字段混合存储:将频繁访问的热字段与不常使用的冷字段拆分为不同结…

    2025年12月18日 好文分享
    000
  • C++ multimap如何使用 允许重复键的关联容器详解

    在c++++中,std::multimap用于存储多个相同键的关联容器。它允许插入多个相同键值,使用insert()函数可添加单个或批量元素;查找时需用equal_range()获取指定键的所有元素;遍历默认按键升序排列,也可自定义排序规则;删除时可用erase()删除特定位置或所有相同键元素,需注…

    2025年12月18日 好文分享
    000
  • 智能指针的引用计数存放在哪 深入理解控制块内存结构

    引用计数并不直接存在于对象内部,而是存储在独立的控制块中。1. 控制块包含强引用计数、弱引用计数、自定义删除器、分配器及可选的对象本身;2. 引用计数不放在对象内部的原因包括避免侵入性设计、支持多态和继承、确保 weak_ptr 的安全性以及存储管理信息;3. 使用 std::make_shared…

    2025年12月18日 好文分享
    000
  • 怎样理解C++的内存对齐规则 结构体内存布局优化原理

    c++++的内存对齐规则和结构体内存布局优化是为了提升访问效率并减少空间浪费。1. 内存对齐要求数据起始地址能被其类型大小整除,以避免cpu多次读取影响性能,例如int通常需4字节对齐;2. 结构体优化应先放大成员后放小成员,以减少填充字节,如调整顺序可使结构体从12字节减至8字节;3. 编译器对齐…

    2025年12月18日 好文分享
    000
  • 结构体与元组怎么选择 对比std tuple与自定义结构体优劣

    在rust中,选择结构体还是元组取决于数据的语义和使用场景。1. 若需明确语义、长期维护或扩展,结构体更优;2. 若仅需临时、小规模数据组合,元组更简洁。结构体通过命名字段提升可读性和可维护性,适合封装有业务含义的数据实体、作为公共api、需扩展或关联行为的场景。元组则依赖索引访问,适合函数内部返回…

    2025年12月18日 好文分享
    000
  • 结构体大小如何计算 考虑对齐规则与填充字节的影响

    结构体大小的计算并非简单相加,而是受数据对齐和填充字节的影响。1. 数据对齐是为了提升cpu访问内存效率,成员起始地址需是其对齐值的整数倍;2. 结构体整体大小必须是最大成员对齐值的整数倍,否则需在末尾填充;3. 成员顺序影响结构体大小,合理排列可减少填充;4. 可使用#pragma pack指令修…

    2025年12月18日 好文分享
    000
  • CPU缓存行对齐实战:消除伪共享的终极指南

    c++pu缓存行对齐是为了避免伪共享从而提升多线程性能的关键手段。1. 伪共享是指多个线程修改不同数据时,因这些数据位于同一缓存行而引发缓存一致性协议频繁介入,导致性能下降的现象;2. 判断伪共享可通过perf工具监控cache-misses指标,或在代码中加入统计逻辑观察线程对缓存行的争用情况;3…

    2025年12月18日 好文分享
    000
  • 怎样编写缓存友好的C++代码 数据局部性原理与内存布局优化

    编写缓存友好的c++++代码需遵循以下要点:1. 利用时间局部性与空间局部性,如循环中复用变量和顺序访问数组;2. 优化数据结构布局,合并同类字段、减少填充、控制对齐方式;3. 调整循环访问模式,按内存布局顺序访问、分块处理;4. 使用缓存友好的容器与算法,如std::vector、std::sor…

    2025年12月18日 好文分享
    000
  • C++数组存储结构体有什么讲究?讨论内存对齐影响

    结构体数组存储效率受内存对齐影响。1. 内存对齐为提高cpu访问效率,使结构体成员按特定地址存放,可能引入padding,增加内存占用;2. 成员顺序影响padding大小,合理排列可减少空间浪费;3. 可使用#pragma pack或alignas手动控制对齐方式,但需权衡内存与性能;4. 未对齐…

    2025年12月18日 好文分享
    000
  • C++简易日历程序怎么开发 日期计算与格式化输出

    要准确判断闰年并处理日期边界问题,需遵循1.能被4整除但不能被100整除,或能被400整除的年份是闰年;2.根据月份返回对应天数,如1、3、5、7、8、10、12月为31天,4、6、9、11月为30天,2月根据是否为闰年返回28或29天;3.使用sakamoto’s算法计算星期几,通过数…

    2025年12月18日 好文分享
    000

发表回复

登录后才能评论
关注微信