寒窗轩,寒川的个人网络博客,记录互联网事,学习网络编程、分享工作经验、人生感悟,包括但不限于程序代码、数据库、Office办公、随笔等内容。

MySQL如何按每个分类查询10条数据,即MySQL如何每个分类查询10条数据

MySQL如何按每个分类查询10条数据,这是做网站开发中通常会遇到的问题。实现方法很多,今天直接上干货,也不做过多的解释,了解就好。表结构如下图:

表结构.jpg

具体sql语句如下:

SELECT id,category_id,title,keywords,description,view,download,size,prefer,price,page,preview,image,type,t,file,search
FROM (  
    SELECT   
        id,category_id,title,keywords,description,view,download,size,prefer,price,page,preview,image,type,t,file,search,  
        @row_num := IF(@prev_category = category_id, @row_num + 1, 1) AS row_number,  
        @prev_category := category_id  
    FROM   
        content,  
        (SELECT @row_num := 0, @prev_category := NULL) r  
    ORDER BY   
        category_id asc, id asc
) AS ranked_results  
WHERE row_number <= 10;

更高效的语句如下:

SELECT 
    c.*
FROM 
    content as c
JOIN
    (SELECT
        id,
        @row_num := IF(@prev_category = category_id, @row_num + 1, 1) AS row_number,
        @prev_category := category_id
    FROM
        content,
        (SELECT @row_num := 0, @prev_category := NULL) r
    ORDER BY
        category_id ASC, id ASC
    ) AS ranked_results
    ON c.id = ranked_results.id
WHERE 
    row_number <= 10;


程序 2024-03-12 20:53:55 7 0 2379 mysql优化
文章写得不错?我是土豪我要在线打赏!
在线打赏

昵称:

验证码:验证码

评论:

文章分类
系统
程序
数据
Office
随笔
热门文章
请不要奇怪,为什么最近博客的文章是几年前的内容
Excel动态引用各表格指定单元格数据
开篇第一章
ubuntu24.04无法安装向日葵,提示依赖libgconf-2-4怎么办?
发现一个好网站——春燕文档
ubuntu24.04安装网易云音乐
Ubuntu22.04中用thunar替换默认文件管理器,提示无法启动“TerminalEmulator“的首选应用程序
MySQL如何按每个分类查询10条数据,即MySQL如何每个分类查询10条数据
python读取旧的Excel文件的数据到新的Excel表中
nginx+php如何EventStream流式数据传输
文章推荐
免责声明
关于博主
开篇第一章
随机推荐
这个flash太有才了,不得不佩服制作者的想象力。。。。超级强悍的计算机病毒。呵呵。
毕业论文:生物柴油的合成
终于下雨了
excel无重复排序,如何提取排名前5的学生对应姓名
gb2312编码页面post到utf-8页面乱码解决方案
简单而全面的sql查询教程(一)
apache将其他域名(如带www的域名)转向不带www的域名
win10切换虚拟桌面
QQ.exe - 无法找到组件:没有找到ComRes.dll,因此这个应用程序未能启动。重新安装应用程序可能会修复此问题。
腾讯云服务器快照恢复删除的数据
友情连接
春燕网络
谢润的博客