首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL 分组排序后 → 如何取N或倒数N

N或倒数N   我们回到标题,分组排序后,如何取N记录或倒数N记录   循环查数据库   1、先批量查询 task_id   2、再根据 task_id 逐个去查 t_task_exec_log...,排序获取N记录   3、最后进行一个数据汇合,封装成页面需要的数据格式   但这种方式会循环查数据库,一般是被禁止的   GROUP BY 结合 MySQL 函数   1、先批量查询 task_id...  2、再根据这些 task_id 从 t_task_exec_log 批量查询每个任务的N记录的 log_id 集字符串 SELECT task_id, SUBSTRING_INDEX(GROUP_CONCAT...关于窗口函数可查阅官方文档:Window Functions,不做过多介绍   我们用 ROW_NUMBER 来实现 取N或倒数N   1、批量查询 task_id   2、使用 ROW_NUMBER...,取N或倒数N   取第一   结果如下   取 5 SELECT * from ( SELECT *, ROW_NUMBER() OVER(PARTITION BY task_id

1.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL分组查询后取每组的N记录

    而业务系统的官网上需要滚动展示一些热门资讯信息列表(浏览量越大代表越热门),而且每个别的相关资讯记录至多显示3,换句话:“按照资讯分类分组,取每组的3资讯信息列表”。...资讯信息记录表 需求 :取热门的资讯信息列表且每个类别只取3。 二、核心思想 一般意义上我们在取N记录时候,都是根据某个业务字段进行降序排序,然后取N就能实现。...但是当你仔细阅读我们的题目要求,你会发现:“它是让你每个类型下都要取浏览量的3记录”。 一种比较简单但是粗暴的方式就是在Java代码中循环所有的资讯类型,取出每个类型的3记录,最后进行汇总。...要计算出某资讯信息的在同资讯分类下所有记录中排第几名,换成算出 有多少浏览量比当前记录的浏览量高,然后根据具体的多少(N+1就是N+1就是当前记录所在其分类下的的排名。...就正如案例中求记录的所在分类的排名,把其对等的“转换成有多少同类别的记录的浏览量比当前记录的大(count聚合函数)” 问题马上就迎刃而解了。 (完)

    26.5K32

    效率提高N倍的19MySQL优化秘籍

    三、SELECT语句务必指明字段名称 ---- SELECT *增加很多不必要的消耗(cpu、io、内存、网络带宽);增加了使用覆盖索引的可能性;当表结构发生改变时,断也需要更新。...四、当只需要一数据的时候,使用limit 1 ---- 这是为了使EXPLAIN中type列达到const类型 五、如果排序字段没有用到索引,就尽量少排序 ---- 六、如果限制条件中其他字段没有索引...优化的方法如下:可以取一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。比如此列中,上一页最大的id是866612。...庆幸的是在MySQL中,有全文索引来帮助我们。...LEFT JOIN A表为驱动表 INNER JOIN MySQL会自动找出那个数据少的表作用驱动表 RIGHT JOIN B表为驱动表 注意:MySQL中没有full join,可以用以下方式来解决

    52630

    效率提高N倍的19MySQL优化秘籍

    三、SELECT语句务必指明字段名称 ---- SELECT *增加很多不必要的消耗(cpu、io、内存、网络带宽);增加了使用覆盖索引的可能性;当表结构发生改变时,断也需要更新。...四、当只需要一数据的时候,使用limit 1 ---- 这是为了使EXPLAIN中type列达到const类型 五、如果排序字段没有用到索引,就尽量少排序 ---- 六、如果限制条件中其他字段没有索引...优化的方法如下:可以取一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。比如此列中,上一页最大的id是866612。...庆幸的是在MySQL中,有全文索引来帮助我们。...LEFT JOIN A表为驱动表 INNER JOIN MySQL会自动找出那个数据少的表作用驱动表 RIGHT JOIN B表为驱动表 注意:MySQL中没有full join,可以用以下方式来解决

    61620

    效率提高N倍的19MySQL优化秘籍

    三、SELECT语句务必指明字段名称 ---- SELECT *增加很多不必要的消耗(cpu、io、内存、网络带宽);增加了使用覆盖索引的可能性;当表结构发生改变时,断也需要更新。...四、当只需要一数据的时候,使用limit 1 ---- 这是为了使EXPLAIN中type列达到const类型 五、如果排序字段没有用到索引,就尽量少排序 ---- 六、如果限制条件中其他字段没有索引...优化的方法如下:可以取一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。比如此列中,上一页最大的id是866612。...庆幸的是在MySQL中,有全文索引来帮助我们。...LEFT JOIN A表为驱动表 INNER JOIN MySQL会自动找出那个数据少的表作用驱动表 RIGHT JOIN B表为驱动表 注意:MySQL中没有full join,可以用以下方式来解决

    52620

    MySQL事务隔离级别原来这么简单

    事务执行过程中出错,会回滚到事务开始的状态,所有的操作就像没有发生一样。例如,如果一个事务需要新增 100 记录,但是在新增了 10 记录之后就失败了,那么数据库将回滚对这 10 新增的记录。...要求每个读写事务的对象对其他事务的操作对象能互相分离,即该事务提交对其他事务不可见。也可以理解为多个事务并发访问时,事务之间是隔离的,一个事务不应该影响其它事务运行效果。...2 MySQL4种事务隔离级别分析 隔离 级别 事务隔离级别概述 SQL标准定义了4隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的。...MySQL数据库实现了这以上4种隔离级别,每种隔离级别可能会产生的问题如下表所示: 隔离级别 脏读 不可重复读 幻读 Read Uncommitted Y Y Y Read Committed N...Y Y Repeatable Read N N Y Serializable N N N 隔离 级别 测试各种隔离级别 创建一张Student表。

    45110

    MVCC原理探究及MySQL源码实现分析

    由于MySQL支持多种隔离级别,这个问题是需要看session2的事务隔离级别的,情况如下: 隔离级别为 READ-UNCOMMITTED 情况下: session 1 commit前后 session...2、通过read view判断行记录是否可见 具体的判断流程如下: RR隔离级别下,在每个事务开始的时候,会将当前系统中的所有的活跃事务拷贝到一个列表中(read view) RC隔离级别下,在每个语句开始的时候...MVCC解决了什么问题 MVCC使得数据库读不会对数据加锁,select不会加锁,提高了数据库的并发处理能力 借助MVCC,数据库可以实现RC,RR等隔离级别,用户可以查看当前数据的一个或者几个历史版本...))); ut_ad(table->magic_n == DICT_TABLE_MAGIC_N); ut_ad(!...查看他是怎么判断记录的看见性,中间函数调用太多列举最重要部分 这里需要介绍一个重要的 ReadView,Read View是事务开启时当前所有事务的一个集合,这个中存储了当前Read View中最大事务

    2.2K90

    数据库四大特性及数据库隔离级别

    将多个事务隔离开,每个事务都不能访问到其他事务操作过程中的状态。 关于事务的隔离性,数据库也提供了多种方案,后面我们将会进行详细介绍 4....隔离级别说明 MySQL定义了四种隔离级别,包括一些具体规则,用于限定事务内外哪些改变是可见的,哪些改变是不可见的。低级别的隔离一般支持更高的并发处理,并且拥有更低的系统开销。...,一个事务从开始到提交,所做的任何数据改变都是不可见的,除非已经提交。...简而言之,SERIALIZABLE是在每个读的数据行上加锁。...它的作用是每一单独的查询都是一个事务,自动开始,自动提交(语句执行完成就提交。

    1.1K10

    MySQL命令行监控工具 - mysqlstat 介绍

    MySQL命令行监控工具 - mysqlstat 介绍mysqlstat 是一个命令行工具,功能如下:实时监控mysql服务器的QPS、TPS、网络带宽指标查看执行次数最频繁的NSQL语句查看访问次数最频繁的...N张表文件ibd查看当前锁阻塞的SQL查看死锁信息查看重复或冗余的索引查看应用端IP连接数总和统计库里每个表的大小MySQL命令行监控工具 - mysqlstatoptions: -h, --help...Mysql Password --top TOP 需要提供一个整数类型的参数值,该参数值表示执行次数最频繁的NSQL语句...--io IO 需要提供一个整数类型的参数值,该参数值表示访问次数最频繁的N张表文件ibd --lock 查看当前锁阻塞的SQL --dead.../mysqlstat -H 192.168.198.239 -P 6666 -u admin -p 'hechunyang'图片执行次数最频繁的10SQL语句shell> .

    74400
    领券