mysql - replace into/group by 重复记录保留规则测试

本文探讨了SQL中`REPLACE INTO`和`GROUP BY`语句在处理重复记录时的保留规则。对于`REPLACE INTO`,在`UNION ALL`和有序`ORDER BY`场景下,分别展示了如何保留最后一个记录。而在`GROUP BY`操作中,分析了默认情况下以及带有`ORDER BY`和`LIMIT`的情况,如何决定重复记录的保留。总结了SQL在处理重复数据时的关键策略。
摘要由CSDN通过智能技术生成

目录

1.replace into 重复记录保留规则

(1)情景1: union all 中重复

(2)order by 中重复

2.group by 重复记录保留规则

(1)默认情况

(2)order by 排序情况

(3)嵌套加上limit 999999999


1.replace into 重复记录保留规则

(1)情景1: union all 中重复

结论:保留最后union all 中的记录

replace into test.temp_test

select 'jim' , 1 union all

select 'jim' , 2 union all

select 'jim' , 3;

 

 

(2)order by 中重复

结论:保留order by 排序中最后一条

create table test.temp_test_01 as

select 'jim' name , 1 id union all

select 'jim' , 2 union all

select 'jim' , 3 union all

select 'jack' , 1 union all

select 'jack' , 2 union all

select 'jack' , 3 union all

select 'tom' , 1 union all

select 'tom' , 2 union all

select 'tom' , 3

;

replace into test.temp_test select * from test.temp_test_01 order by name , id desc;

 

replace into test.temp_test select * from test.temp_test_01 order by name , id asc;

 

2.group by 重复记录保留规则

源数据:

 

(1)默认情况

结果:默认保留select排序中第一条

select * from test.temp_test_01 group by name ;

 

 

(2)order by 排序情况

结果: 不管嵌套中正或反排序,还是和默认情况一样

 

 

 

(3)嵌套加上limit 999999999

结果: 嵌套倒排序后 加上 limit 99999999 后 ,取最后一条

注意:limit 99999999 必须加,否则不会排序

 

结果: 嵌套正排序后 加上 limit 99999999 后 ,取第一条

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值