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

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

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

分组后第一记录   我们先来简单回顾下实现方式   1、循环查数据库     逻辑很清晰,实现起来也很简单,但是会循环查数据库,开发规范一般会明确禁止这种写法   2、 GROUP BY 结合 MySQL...N或倒数N   我们回到标题,分组排序后,如何N记录或倒数N记录   循环查数据库   1、先批量查询 task_id   2、再根据 task_id 逐个去查 t_task_exec_log...MySQL8 新增的特性   关于窗口函数可查阅官方文档:Window Functions,不做过多介绍   我们用 ROW_NUMBER 来实现 N或倒数N   1、批量查询 task_id...  2、使用 ROW_NUMBER ,N或倒数N   第一   结果如下   前 5 SELECT * from ( SELECT *, ROW_NUMBER() OVER...再看 GROUP BY 结合 MySQL 函数   我们仔细看看 GROUP BY 结合 MySQL 函数 倒数 5 的结果   我们发现和窗口函数的倒数 5 的结果不一致   那到底是哪种方式不对

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

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

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

26K32

MYSQL学习:GROUP BY分组最新的一记录

日常开发当中,经常会遇到查询分组数据中最新的一记录,比如统计当前系统每个人的最新登录记录、外卖系统统计所有买家最新的一次订单记录、图书管理系统借阅者最新借阅书籍的记录等等。...INTO `bookinfo` VALUES (5, 'ISBN005', '物理'); INSERT INTO `bookinfo` VALUES (13, 'ISBN006', '读者'); -- 借阅记录表...c on c.uid=a.user_id GROUP BY a.user_id -- 说明: 这样会存在获取书籍名称错乱的情况, -- 因为使用聚合函数获取的书籍名称,不一定是对应用户 -- 最新浏览记录对应的书籍名称...写法2 采用子查询的方式,获取借阅记录表最近的浏览时间作为查询条件 select a.user_id ,c.uname,a.borrowtime ,b.book_name book_namefrom

18.5K20

mysql查找最后一记录_mysql查询记录总数

分组最新的一记录(整条记录) mysql分组后最新的一记录,下面两种方法.一种是先筛选 出最大和最新的时间,在连表查询.一种是先排序,然后在次分组查询(默认第一),就是最新的一数据了 select...查询第几行到第几行记录 查询最后一行和第一行记录 查询前几行和后几行记录 1、查询第一行记录: select * from table limit 1 2、查询n行到m行记录 select *...from table1 limit n-1,m-n; SELECT * FROM table LIMIT 5,10;返回6行到15行的记录 select * from employee limit...3,1; // 返回4行 3、查询前n记录 select * from table1 limit 0,n; 或 select * from table1 limit n; 4、查询后n记录 select...* from table1 order by id desc dlimit n;//倒序排序,n行 id为自增形式 5、查询一记录($id)的下一记录 select * from table1

6.5K20

从mysqldump自定义导出n记录说起

很多时候DBA需要导出部分记录至开发、测试环境,因数据量需求较小,如果原库的记录多,且表数量也多,在用mysqldump命令导出时可以添加一个where参数(如自定义导出n记录),而不必全量导出。...示例脚本如下: 导出dbname库每张表的1000记录 /usr/local/mysql5.7/bin/mysqldump --skip-add-locks --master-data=2 --.../mysql3307/tmp/mysql3307.sock dbname tbname >tbname.sql 2、导出表结构却不导出表数据——只返回特定数据库特定表格的表格结构,不返回数据,添加...utf8 -E --single-transaction -R --triggers -uroot -pxxxx --socket=/data/mysql/mysql3307/tmp/...-E --single-transaction -R --triggers -uroot -pxxxx --socket=/data/mysql/mysql3307/tmp/mysql3307

1.8K30

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

[:2] 这样获取2个记录会导致性能问题,原因如下: “ 对于有着相当多数量记录的表来说,这种方法异常糟糕。这会导致一个 ORDER BY RAND() 的SQL查询。...MyModel.objects.all()[index1] MyObj2 = MyModel.objects.all()[index2] ” 如上Manganeez所说的方法,相应的获取n记录的代码应该如下...FROM TABLE 通常情况下Django会不显示其他的结果,这样你不会真正的获取到所有的记录。...randomrecords_record; args=() [05/Dec/2013 19:23:06] "GET /dbtest/test3 HTTP/1.1" 200 15 数据量再次提升至百万级别 1066768数据...[:2] 来获取随机记录序列,性能不会比 Python sample = random.sample(xrange(Record.objects.count()),n) result = [Record.objects.all

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
领券