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

昵称:

验证码:验证码

评论:

文章分类
系统
程序
数据
Office
随笔
热门文章
python读取文件夹下图片并生成pdf文件
VB.net开发的word转pdf的小工具
使用python把word转成pdf
文章推荐
免责声明
关于博主
开篇第一章
随机推荐
word使用技巧,插入带圈的数字。
一款绝佳的IM即时通软件MirandaIM
说说银行收取点钞费
抽空用php写了个微信机器人小蜜蜂
硫酸法钛白自生晶种水解工艺
windows&office序列号查看软件
利用宏从Word、Excel中提取Flash
emlog YY统计插件不稳定修复测试
php遍历文件夹读取文件夹中图片并分页显示图片
At her home
友情连接
春燕网络
谢润的博客
企安文档