寒窗轩,寒川的个人网络博客,记录互联网事,学习网络编程、分享工作经验、人生感悟,包括但不限于程序代码、数据库、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 13 0 2660 mysql优化
文章写得不错?我是土豪我要在线打赏!
在线打赏

昵称:

验证码:验证码

评论:

文章分类
系统
程序
数据
Office
随笔
热门文章
请不要奇怪,为什么最近博客的文章是几年前的内容
开篇第一章
ubuntu24.04无法安装向日葵,提示依赖libgconf-2-4怎么办?
ubuntu24.04安装网易云音乐
Ubuntu22.04中用thunar替换默认文件管理器,提示无法启动“TerminalEmulator“的首选应用程序
MySQL如何按每个分类查询10条数据,即MySQL如何每个分类查询10条数据
python读取旧的Excel文件的数据到新的Excel表中
nginx+php如何EventStream流式数据传输
python读取文件夹下图片并生成pdf文件
文章推荐
免责声明
关于博主
开篇第一章
随机推荐
简单的一个asp的分页程序
dedecms挂马清理记
腾讯空间Qzone,你别乱屏蔽好不?
毕业感慨
access的mdb数据库长期使用变大的处理办法
动易系统的数据库连接出错,请检查Conn.asp文件中的数据库参数设置解决方案。
洗衣
说说银行收取点钞费
筹划个小插件
实验常用正交表
友情连接
春燕网络
谢润的博客