1、(需求问题解决方案)根据表中某个字段分组并获取其时间为最新的数据

在我们日常工作中,会有这样的需求,假设一张学生表有主键、姓名、学号、年龄、创建时间等字段,但是我们有个需求就是:根据学号分组且每条数据都是创建时间为最新的数据

表结构如下:

CREATE TABLE `user` (
    `id` int(11) NOT NULL AUTO_INCREMENT,
    `username` varchar(20) DEFAULT NULL,
    `password` varchar(20) DEFAULT NULL,
    `age` int(11) DEFAULT NULL,
    `sex` char(255) DEFAULT NULL,
    `email` varchar(20) DEFAULT NULL,
    `idCard` varchar(100) DEFAULT NULL COMMENT '学号',
    `time` datetime DEFAULT NULL COMMENT '创建时间',
    PRIMARY KEY (`id`)
 ) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8     

实现思路1:

  1. 子查询 (SELECT 统一信用代码, MAX(更新时间) AS max_time FROM your_table GROUP BY 统一信用代码) 用于找出每个统一信用代码的最新时间。
  2. 主查询通过将子查询的结果与原始表进行内连接,返回每个统一信用代码的最新记录。

具体代码实现:

SELECT 
    t1.*  
FROM  
    user t1
INNER JOIN (
    SELECT
        idCard,
        MAX(time) AS max_time
    FROM
        user
    GROUP BY idCard
) t2 ON t1.idCard = t2.idCard AND t1.time = t2.max_time

表数据:

运行结果:

实现思路2(note:窗口函数从mysql8.0开始支持):

  1. 使用了窗口函数 ROW_NUMBER() 来为每个统一信用代码的记录分配一个行号。通过 PARTITION BY 子句,我们按统一信用代码对数据进行分组,并使用 ORDER BY 子句按更新时间降序排列。这样,每个统一信用代码的最新记录将被分配行号 1。然后,外部查询过滤出行号为 1 的记录,从而只返回每个统一信用代码的最新数据。

具体代码实现:

SELECT 
    t.*
FROM
    (
        SELECT
            a.*,
            ROW_NUMBER() OVER (PARTITION BY a.idCard ORDER BY a.time DESC) AS rn
        FROM
            user a
    ) t
WHERE
    t.rn = 1;

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只鸟儿

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值