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

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

分组后第一记录   我们先来简单回顾下实现方式   1、循环查数据库     逻辑很清晰,实现起来也很简单,但是会循环查数据库,开发规范一般会明确禁止这种写法   2、 GROUP BY 结合 MySQL...N或倒数N   我们回到标题,分组排序后,如何N记录或倒数N记录   循环查数据库   1、先批量查询 task_id   2、再根据 task_id 逐个去查 t_task_exec_log...,排序获取前N记录   3、最后进行一个数据汇合,封装成页面需要的数据格式   但这种方式会循环查数据库,一般是被禁止的   GROUP BY 结合 MySQL 函数   1、先批量查询 task_id...,N或倒数N   第一   结果如下   前 5 SELECT * from ( SELECT *, ROW_NUMBER() OVER(PARTITION BY task_id...再看 GROUP BY 结合 MySQL 函数   我们仔细看看 GROUP BY 结合 MySQL 函数 倒数 5 的结果   我们发现和窗口函数的倒数 5 的结果不一致   那到底是哪种方式不对

89910

mysql分组最大(最小、最新、前N)记录

数据库开发过程中,我们要为每种类型的数据取出前几条记录,或者是最新、最小、最大等等,这个该如何实现呢,本文章向大家介绍如何实现mysql分组最大(最小、最新、前N)记录。...5, 'b5'); 数据表如下: name val memo a 2 a2 a 1 a1 a 3 a3 b 1 b1 b 3 b3 b 2 b2 b 4 b4 b 5 b5 按name分组val...GROUP BY name ORDER BY val desc; 以上六种方法运行的结果均为如下所示: name val memo a 3 a3 b 5 b5 小编推荐使用第一、第三、第四钟方法,结果显示1,3,4...种方法效率相同,2,5种方法效率差些。...tb a where val = (select top 1 val from tb where name = a.name) order by a.name //这个是sql server的 //mysql

8.6K30
您找到你想要的搜索结果了吗?
是的
没有找到

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

首先,我们知道MySQL数据库分组功能主要是通过GROUP BY关键字来实现的,而且GROUP BY通常得配合聚合函数来使用用,比如说分组之后你可以计数(COUNT),求和(SUM),求平均数(AVG)...而业务系统的官网上需要滚动展示一些热门资讯信息列表(浏览量越大代表越热门),而且每个类别的相关资讯记录至多显示3,换句话:“按照资讯分类分组,每组的前3资讯信息列表”。...一、数据准备 数据库: MySQL 8.0社区版 表设计 资讯分类表: id 主键 name 分类名称 资讯信息记录表: code 说明 id 主键 title 资讯名称 views 浏览量 info_type_id...资讯信息记录表 需求 :热门的资讯信息列表且每个类别只前3。 二、核心思想 一般意义上我们在N记录时候,都是根据某个业务字段进行降序排序,然后N就能实现。...要计算出某资讯信息的在同资讯分类下所有记录中排第几名,换成算出 有多少浏览量比当前记录的浏览量高,然后根据具体的多少(N+1就是N+1就是当前记录所在其分类下的的排名。

26K32

使用Django从数据库中随机N记录的不同方法及其性能实测

不同数据库数据库服务器的性能,甚至同一个数据库的不同配置都会影响到同一段代码的性能。具体情况请在自己的生产环境进行测试。...举个栗子,这里是MYSQL是如何处理这个查询的(其他数据库的情况也差不多),想象一下当一个表有十亿行的时候会怎样: 为了完成ORDER BY RAND() ,需要一个RAND()列来排序 为了有RAND...MyModel.objects.all()[index1] MyObj2 = MyModel.objects.all()[index2] ” 如上Manganeez所说的方法,相应的获取n记录的代码应该如下...project中新建一个app,数据库MYSQL: D:\PyWorkspace\DjangoTest>python manage.py startapp randomrecords 在models.py...附上三种方法数据量和SQL时间/总时间的数据图表: 最后总结,Django下,使用mysql数据库,数据量在百万级以下时,使用 Python Record.objects.order_by('?')

7K31

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

原文:http://www.enmotech.com/web/detail/1/700/1.html  (复制链接,打开浏览器即可查看原文) 一、EXPLAIN ---- 做MySQL优化,我们要善用 ...四、当只需要一数据的时候,使用limit 1 ---- 这是为了使EXPLAIN中type列达到const类型 五、如果排序字段没有用到索引,就尽量少排序 ---- 六、如果限制条件中其他字段没有索引...优化的方法如下:可以前一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。比如此列中,上一页最大的id是866612。...庆幸的是在MySQL中,有全文索引来帮助我们。...LEFT JOIN A表为驱动表 INNER JOIN MySQL会自动找出那个数据少的表作用驱动表 RIGHT JOIN B表为驱动表 注意:MySQL中没有full join,可以用以下方式来解决

59920

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

一、EXPLAIN ---- 做MySQL优化,我们要善用 EXPLAIN 查看SQL执行计划。 下面来个简单的示例,标注(1,2,3,4,5)我们要重点关注的数据 ? type列,连接类型。...四、当只需要一数据的时候,使用limit 1 ---- 这是为了使EXPLAIN中type列达到const类型 五、如果排序字段没有用到索引,就尽量少排序 ---- 六、如果限制条件中其他字段没有索引...优化的方法如下:可以前一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。比如此列中,上一页最大的id是866612。...庆幸的是在MySQL中,有全文索引来帮助我们。...LEFT JOIN A表为驱动表 INNER JOIN MySQL会自动找出那个数据少的表作用驱动表 RIGHT JOIN B表为驱动表 注意:MySQL中没有full join,可以用以下方式来解决

51230

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

出处:https://zhuanlan.zhihu.com/p/49888088 作者:喜欢拿铁的人 一、EXPLAIN ---- 做MySQL优化,我们要善用 EXPLAIN 查看SQL执行计划。...四、当只需要一数据的时候,使用limit 1 ---- 这是为了使EXPLAIN中type列达到const类型 五、如果排序字段没有用到索引,就尽量少排序 ---- 六、如果限制条件中其他字段没有索引...优化的方法如下:可以前一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。比如此列中,上一页最大的id是866612。...庆幸的是在MySQL中,有全文索引来帮助我们。...LEFT JOIN A表为驱动表 INNER JOIN MySQL会自动找出那个数据少的表作用驱动表 RIGHT JOIN B表为驱动表 注意:MySQL中没有full join,可以用以下方式来解决

51720

Mysql数据库MySQL数据库开发的 36 军规

核心军规 尽量不在数据库做运算 控制单表数据量 纯INT不超过10M,含Char不超过5M 保持表身段苗条 平衡范式和冗余 拒绝大SQL,复杂事务,大批量任务 字段类军规 用好数值字段,尽量简化字段位数...把字符转化为数字 优先使用Enum或Set 避免使用Null字段 少用并拆封Text/Blob 不在数据库中存图片 索引类军规 谨慎合理添加索引 字符字段必须建立前缀索引?...数据库的字符集,要用 utf8mb4,而不是utf8。...因为MySQL的utf8不是真正的UTF-8,只支持最多三个字节的字符。真正的UTF-8可能会出现四个字节的字符。...MySQL 从来没有修复这个 Bug,而是使用另外的解决方法:真正的UTF-8字符集用 utf8mb4的名字提供。

5.2K20

N天爆肝数据库——MySQL(1)

N天爆肝数据库——MySQL(1) 这是专栏链接,大家可以看一看,提提意见 数据库概念理解 数据库 DB 存储数据的仓库 数据库管理系统 DBMS 操纵和管理数据库的大型软件 SQL 操作关系型数据库的编程语言...,定义了用一套操作关系型数据库同意标准 学习 SQL 的作用 SQL 是一门 ANSI 的标准计算机语言,用来访问和操作数据库系统。...SQL 面向数据库执行查询 SQL 可从数据库取回数据 SQL 可在数据库中插入新的记录 SQL 可更新数据库中的数据 SQL 可从数据库删除记录 SQL 可创建新数据库 SQL 可在数据库中创建新表...MySQL数据库的SQL语句不区分大小写,关键字建议使用大写。 4)....字段n 字段n类型[COMMENT 字段n注释], )[COMMENT 表注释]; DDL-表操作-数据类型 数值类型 整形 TINYINT 1bt SMALLINT 3bt MEDIUMINT

15340

N天爆肝数据库——MySQL(4)

N天爆肝数据库——MySQL(4) 这是专栏链接,大家可以看一看,提提意见 本篇文章,主要对多表查询,事务以及体系结构进行知识总结和学习。 期待和大家一起学习进步。...默认MySQL的事务是自动提交的,也就是说,当执行一DML语句,MySQL会立即 隐式的提交事务。...隔离性:数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立 环境下运行。 持久性:事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。...不可重复读:一个事务先后读取一记录,但两次读取的数据不同,称之为不可 重复读。...字段n 字段n类型[COMMENT 字段n注释] )ENGINE=INNODB[COMMENT 表注释]; 查看当前数据库支持的存储引擎 SHOW ENGINES; 存储引擎特点 InnoDB 介绍

18810

N天爆肝数据库——MySQL(2)

N天爆肝数据库——MySQL(2) 这是专栏链接,大家可以看一看,提提意见 本篇文章,主要对DML DQL进行知识总结和学习。 期待和大家一起学习进步。...DML-介绍 DML(数据库操作语言),用来对数据库中表的数据 记录进行增删改操作。...FROM 表名; 注意:null不参与聚合运算 DQL-分组查询(GROUP BY) 语法 SELECT 字段列表 FROM 表名[WHERE条件]GROUP BY 分组字段名[HAVING 分组后过滤...DQL-分页查询 语法 SELECT 字段列表 FROM 表名 LIMIT 起始索引,查询记录数; 注意 起始索引从0开始,起始索引=(查询页码-1)*每页显示记录数 分页查询是数据库的方言,不同的数据库有不同的实现...,MySQL中是LIMIT 如果查询的是第一页数据,起始索引可以省略,直接写为limit 10 DQL-执行顺序 FROM 表名列表 WHERE 条件列表 GROUP BY 分组字段列表 HAVING

14220

N天爆肝数据库——MySQL(3)

N天爆肝数据库——MySQL(3) 这是专栏链接,大家可以看一看,提提意见 本篇文章,主要对DCL、 函数、 约束和多表查询进行知识总结和学习。 期待和大家一起学习进步。...DCL DCL-介绍 数据控制语言,用来管理数据库用户、控制数据库的访问权限。...DCL-权限控制 MySQL常用 ALL,ALL PRIVILEGES 所有权限 SELECT 查询 INSERT 插入 UPDATE 修改 DELETE 删除 ALTER 修改表 DROP 删除数据库...pad)左填充,用字符串pad对str的左边进行填充,达到n个字符串长度 RPAD(str,n,pad)右填充,用字符串pad对str的右边进行填充,达到n个字符串长度 TRIM(str)去掉字符串头部和尾部的空格...SUBSTRING(str,start,len)返回从字符串str从start位置起的len个长度的字符串 常用的数值函数 CEIL(x)向上整 FLOOR(x)向下整 MOD(x,y)返回x/y

16920

MySQL数据库开发的 36 军规!

来自:www.slideshare.net/mysqlops/mysql-9838563 来自一线的实战经验,主要针对DBA和后端开发人员,总是在灾难发生后,才想起容灾的重要性;总是在吃过亏后,才记得曾经有人提醒过...核心军规 尽量不在数据库做运算 控制单表数据量 纯INT不超过10M,含Char不超过5M 保持表身段苗条 平衡范式和冗余 拒绝大SQL,复杂事务,大批量任务 字段类军规 用好数值字段,尽量简化字段位数...把字符转化为数字 优先使用Enum或Set 避免使用Null字段 少用并拆封Text/Blob 不在数据库中存图片 索引类军规 谨慎合理添加索引 字符字段必须建立前缀索引?...Java 10 实战 1 篇:局部变量类型推断 2. 图解 https 单向认证和双向认证 3. 最新后端架构师技术图谱!附学习资料~ 4.

2.2K50

MySQL数据库开发的 36 军规

MySQL数据库开发的 36 军规 标签:数据库 核心军规(5个) 尽量不在数据库做运算。 控制单表数量:行不超过500W,超出分表;列不超过50个,超过拆表。...NULL(NULL字段很难查询优化、NULL字段的索引需要额外空间、NULL字段的复合索引无效) 尽量少用text/blob类型(尽量使用varchar代替text字段),需要的时候请拆表 不在数据库存图片...pinyin`(8)), 不在列上做运算 Innodb主键推荐使用自增列(主键建立聚簇索引,主键不应该被修改,字符串不应该做主键) 不用外键(由程序保证约束) SQL类军规(16个) SQL语句尽可能简单(一SQL...只能在一个cpu运算,大语句拆小语句,减少锁时间,一大SQL可以堵死整个库) 简单的事务(事务时间尽可能短,坏的代码案例:上传图片事务) 避免使用trigger/func(触发器、函数不用,由客户端程序取而代之...limit高效分页(limit越大,效率越低) limit 10000,10 改为 where id >xxx limit 11 使用union all替代union(union有去重开销) 发生高并发时,数据库少用两个表以上的

11510
领券