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

记一次有意思的 SQL 实现 → 分组每组第一条记录

我:滚,我不认识你 需求背景   环境 MySQL 版本:8.0.27   有四张表:业务信息表、任务表、业务任务表、任务执行日志表 CREATE TABLE `t_business` ( `...这里也就对应了文章的标题:分组每组的第 1 条记录     实现方式其实有很多,我这里提供一种,如下     结合索引 idx_status_task_date_modify(exec_status...总结   1、大家写 SQL 的时候,一定要多结合执行计划来写 神奇的 SQL 之 MySQL 执行计划 → EXPLAIN,让我们了解 SQL 的执行过程!   ...多和同事沟通,多和需求方沟通     多和同事沟通,集思广益,说不定就找到合适的解决方案了     多和需求方沟通,多谈谈个人的见解,也许需求改动一丢丢,但我们实现却容易很多   4、留疑     1、分组后如何前...N 条     2、分组后如何倒数 N 条

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

    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条。...假如以本文上面的示例数据说明:就是在计算每个资讯信息记录时,多计算出一列作为其“排名”字段,然后“排名”字段的小于等于3的记录即可。

    26.5K32

    合并求取分组记录的第一条数据

    --------------------------------- 当时初略的想了想,可以用分组取出来,但写了下又不行,于是按照需求,创建一个表并且插入数据来测试: CREATE TABLE MovieInfo...','007'); INSERT INTO MovieInfo VALUES ('007第三部','电影链接13','007'); GO SELECT * FROM MovieInfo; 先写一个分组并求分组后的记录大于...MovieType,Name 无奈结果不是预期的那样,只有1条记录: MovieType Name 007 007第二部 在同事的指导下,说ROW_NUMBER() 可以在给记录编号的同时指定分组...,然后我们分组中编号为1的记录即可,先来分组编号,看看记录情况: SELECT ROW_NUMBER() OVER(partition by MovieType ORDER BY Name) as row...变形金刚 2 变形金刚第三部 电影链接3 变形金刚 3 变形金刚第一部 电影链接1 变形金刚 OK,现在可以给出完整的查询了,这个查询需要用到联合查询,统计那些没有分组的记录

    1.2K100

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

    数据库开发过程中,我们要为每种类型的数据取出前几条记录,或者是最新、最小、最大等等,这个该如何实现呢,本文章向大家介绍如何实现mysql分组最大(最小、最新、前N条)条记录。...: 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最大的值所在行的数据 方法一: select...按name分组val最小的值所在行的数据 方法一: select a.* from tb a where val = (select min(val) from tb where name = a.name...name = a.name and val < a.val) order by a.name 以上五种方法运行的结果均为如下所示: name val memo a 1 a1 b 1 b1 按name分组第一次出现的行所在的数据...tb a where val = (select top 1 val from tb where name = a.name) order by a.name //这个是sql server的 //mysql

    9.2K30

    MySQL(五)汇总和分组数据

    二、分组数据 1、group by创建分组MySQL中,分组是在select语句中的group by子句中建立的,比如: select vend-id,count(*) as num_prods from...products group by vend_id; 这条SQL语句指定了2个列,group by指示MySQL按照vend_id排序并且分组(如果使用group by,则不必指定要计算的每个组) group...by子句指示指示MySQL分组数据,然后都每个组而不是整个结果集进行聚集;关于group by使用,请注意以下规则: ①group by子句可以包含任意数目的列(使得对分组进行嵌套,为数据分组提供更细致的控制...); ②如果在group by子句中嵌套分组数据将在最后规定的分组上进行汇总,即:建立分组时,指定的所有列都一起计算(所以不能从个别列取回数据); ③group by子句中列出的每个列都必须是检索列或有效的表达式...)的那些分组; having和where的区别: where在数据分组前进行过滤,having在数据分组后进行过滤;where排除的行不包括在分组中(这可能会改变计算值,从而影响having子句中基于这些值过滤掉的分组

    4.7K20

    【R语言】dplyr对数据分组各组前几行

    下面这张表就是GO富集分析得到的结果,我们可以根据ONTOLOGY这一列来分组,就可以得到BP,CC和MF三个组。然后每一个组的前10个条目或者前5个条目来绘制柱形图或者气泡图。...那么问题来了,如何分组前几行。今天小编就跟大家分享一个专业处理数据框的函数dplyr。然后基于这个R包,我们用6种不同的方法来实现。...,但是head并没有应用到三个分组上面,而是直接应用到了整个数据框上,事与愿违。...%>% group_by(ONTOLOGY) %>% slice_min(order_by = p.adjust, n = 5) r4 slice_min会根据指定的p.adjust有小到大排序,然后每组前...GO富集分析的结果,默认是会根据校正之后的p值(p.adjust)来由小到大排序,所以基于这个结果,直接取每组的前五行就是最显著的5个条目。

    1.8K21

    MySQL语句与Java代码实现按需过滤企业员工的资质证书

    在企业ERP中,每位员工拥有多个资质证书,资质证书有种类、名称和登记时间,以及变动时间和结束时间的主要属性; 现在有一个需求,员工在系统查看自己的信息之时:同一种类、同一名称、同一登记时间的资质证书,变动时间最近的显示出来...这个地方如果给最新的那条记录,加一个标识,比如加个字段显示x,过滤的时候用sql直接出结果,挺方便的,我问过SAP开发的同事:no; 思路 代码没有新颖的,只说一下我的思路(也可能有些问题): 1、首先用MySQL...语句GROUP BY 已经三个字段的结果分组分组的结果:按照需求将数据分成一组一组的,每组中的数据并按照变动时间,最新的在上面(也就是符合要求的那一条,在最上面) 2、Java代码拿到数据集,进行处理...; 3、刚才上面说了,第一条是符合要求的,就遍历数据集,每组数据集,用List的特点,将所有元素置为相同的元素,与第一条保持一致; 4、去重; 通过简单的方式,实现了这个小的需求; 总结 总结成简单的话..., 1、先分组分组数据按照时间降序排列; 2、再用Java代码处理List,将list的元素用遍历的方式将值设置为一致; 3、将list去重;

    54110

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

    前情回顾   前两天翻自己的博客的时候,翻到了:记一次有意思的 SQL 实现 → 分组每组第一条记录   突然意识到好像有续集没写   翻到结尾,果然有个留疑   但我要强调一点:这是我给你们的留疑...分组第一条记录   我们先来简单回顾下实现方式   1、循环查数据库     逻辑很清晰,实现起来也很简单,但是会循环查数据库,开发规范一般会明确禁止这种写法   2、 GROUP BY 结合 MySQL...前N条或倒数N条   我们回到标题,分组排序后,如何前N条记录或倒数N条记录   循环查数据库   1、先批量查询 task_id   2、再根据 task_id 逐个去查 t_task_exec_log...,封装成页面需要的数据格式   但 GROUP_CONCAT 长度限制是需要考虑的点   新增最新记录表   这种方式比较契合只第一条的情况,不适合取N条的情况   N不固定,这张表的存储数据范围就不好确定...  我们用 ROW_NUMBER 来实现 前N条或倒数N条   1、批量查询 task_id   2、使用 ROW_NUMBER ,前N条或倒数N条   第一条   结果如下   前 5

    1.3K10

    mysql 必知必会整理—数据汇总与分组

    前言 简单整理一下数据汇总与分组 正文 我们经常需要汇总数据而不用把它们实际检索出来,为此MySQL提供了专门的函数。使用这些函数,MySQL查询可用于检索数据,以便分析和报表生成。...这使得能对分组进行嵌套,为数据分组提供更细致的控制 如果在GROUP BY子句中嵌套了分组数据将在最后规定的分组上进行汇总。...products GROUP BY vend_id with ROLLUP 除了能用GROUP BY分组数据外,MySQL还允许过滤分组,规定包括哪些分组,排除哪些分组。...为得出这种数据,必须基于完整的分组而不是个别的行进行过滤。 HAVING和WHERE的差别 这里有另一种理解方法,WHERE在数据分组前进行过滤,HAVING在数据分组后进行过滤。...仅因为你以某种方式分组数据(获得特定的分组聚集值),并不表示你需要以相同的方式排序输出。

    1.6K30

    sql查询基本语法_以下select语句语法正确的是

    数据库是mysql,使用的数据库表名称是my_student....(展示的时候,只会展示分组记录的第一条记录),分组时,一般会结合使用count()、max()、min()、avg()、sum()函数。...; sql语句的意思是:my_student表以c_id进行分组,然后显示分组后的每组的c_id名称、每组的总数、每组的最高、最低、平均身高和每组的年龄总和。...c_id ,sex; 表示的含义是,对整个表先按照c_id进行分组,然后在此分组的基础之上,然后每组再按照sex,进行分组。...C、多字段分组(加上显示每组的某一字段的所有数据) selectc_id,sex,count(*),max(height),min(height),avg(height),sum(age) ,GROUP_CONCAT

    2.9K10

    mysql分组和排序同时使用时查询数据异常

    问题背景: 每个地点每天新增一条数据,要根据地点分组查询出每个设备最新的数据(按创建时间倒序)。...,没有得到我们需要的结果,这是因为group by 和 order by 一起使用时,会先使用group by 分组,并取出分组后的第一条数据,所以后面的order by 排序时根据取出来的第一条数据来排序的...,但是第一条数据不一定是分组里面的最新的数据。...解决方案: 方案一: 使用子查询,先排序查出结果后作为临时表在分组。这里有个坑,必须要加limit,如果没有加,有些版本的数据库也无法查处正确数据。...个人测试:mysql 5.6.19可以查询到正确的数据mysql 5.7.28无法查询到正确的数据

    2K10

    MySQL数据库:第七章:分组查询

    回退至Mysql数据库理论与实战#进阶6:分组查询语法:select 查询列表 ④from 表名——————————①where 分组前条件—— ②group by 分组的字段③having 分组后条件...⑤order by 排序列表 ⑥特点:1、查询列表往往是:分组函数和分组后的字段换句话说,和分组函数一同查询的字段,一般就是分组后的字段2、分组查询的筛选有两种:分组前筛选和分组后筛选连接关键字 位置...筛选的结果集分组前筛选 where group by前面 原始表分组后筛选 having group by后面 分组后的查询结果(虚拟表)结论:分组函数做条件 肯定是 分组后筛选条件!!!...3、分组查询可以通过单个字段,也可以通过多个字段,中间用逗号隔开#1)简单的分组#案例1:查询每个工种的员工平均工资SELECT AVG(salary) 平均工资,job_idFROM employeesGROUP...BY job_id;#2)可以实现分组前的筛选#案例1:查询邮箱中包含a字符的 每个部门的最高工资SELECT MAX(salary) ,department_idFROM employeesWHERE

    42720

    MySQL数据库:第七章:分组查询

    回退至Mysql数据库理论与实战 #进阶6:分组查询 语法: select 查询列表 ④ from 表名——————————① where 分组前条件—— ② group by 分组的字段③ having...分组后条件 ⑤ order by 排序列表 ⑥ 特点: 1、查询列表往往是:分组函数和分组后的字段 换句话说,和分组函数一同查询的字段,一般就是分组后的字段 2、分组查询的筛选有两种:分组前筛选和分组后筛选...连接关键字 位置 筛选的结果集 分组前筛选 where group by前面 原始表 分组后筛选 having group by后面 分组后的查询结果(虚拟表) 结论:分组函数做条件 肯定是 分组后筛选条件...3、分组查询可以通过单个字段,也可以通过多个字段,中间用逗号隔开 #1)简单的分组 #案例1:查询每个工种的员工平均工资 SELECT AVG(salary) 平均工资,job_id FROM employees...GROUP BY job_id; #2)可以实现分组前的筛选 #案例1:查询邮箱中包含a字符的 每个部门的最高工资 SELECT MAX(salary) ,department_id FROM employees

    94910
    领券