sql分组获取不同对象最新一条数据

在工作中遇到需要从大量数据中,针对不同对象筛选出各自最新的一条记录的问题。传统的使用MAX方法效率较低,本文探讨更优解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

工作遇到问题,需要从大量的数据中筛选出最新的一条数据,但是数据属于不同的对象。也就是获取不同对象的最新一条数据。

上例子:

create table `test` (
	`id` int (11),
	`company_name` varchar (2295),
	`type` varchar (2295),
	`create_date` datetime 
); 
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('1','腾讯','3','2019-10-06 14:06:48');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('2','阿里巴巴','1','2019-10-18 14:35:11');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('3','百度','4','2019-10-06 14:35:16');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('4','小米','7','2019-10-26 14:35:20');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('5','华为','8','2019-10-06 14:35:25');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('6','农业银行','9','2019-10-06 14:35:28');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('7','工商银行','6','2019-10-10 14:35:32');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('8','兴业银行','10','2019-10-23 14:35:36');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('9','浦发银行','5','2019-10-06 14:35:40');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('10','贵州茅台','2','2019-10-06 14:35:44');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('11','腾讯','3','2021-10-06 14:06:48');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('12','阿里巴巴','1','2020-10-18 14:35:11');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('13','百度','4','2021-10-06 14:35:16');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('14','小米','7','2021-10-26 14:35:20');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('15','华为','8','2021-10-06 14:35:25');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('16','农业银行','9','2021-09-06 14:35:28');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('17','工商银行','6','2018-10-10 14:35:32');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('18','兴业银行','10','2020-10-23 14:35:36');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('19','浦发银行','5','2021-10-06 14:35:40');
insert into `test` (`id`, `company_name`, `type`, `create_date`) values('20','贵州茅台','2','2021-10-06 14:35:44');


SELECT * FROM test t RIGHT JOIN (SELECT TYPE, MAX(create_date) AS sj FROM test GROUP BY TYPE) tmp ON (t.create_date = tmp.sj AND t.type=tmp.type)

查询之后的结果:

缺点:使用max效率差很多

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

春天的菠菜

一毛两毛也是动力

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

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

打赏作者

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

抵扣说明:

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

余额充值