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

昵称:

验证码:验证码

评论:

文章分类
系统
程序
数据
Office
随笔
热门文章
文章推荐
免责声明
关于博主
开篇第一章
随机推荐
基于ThinkPHP6的API注释文档自动生成扩展
终于升级了。
本博客系统开启评论IP黑名单、关键词黑名单功能
At her home
毕业论文试验感慨
批量设置连接在新窗口打开
夏普sharp ar-2918 显示小人和小太阳灯一直亮清除方法
搜索引擎优化(SEO)的一般步骤
Windows如何隐藏CMD命令运行窗口
简单的一个asp的分页程序
友情连接
春燕网络
谢润的博客
企安文库