解决sql 过滤重复数据记录的方法(Oracle)

分别创建了两个临时表,并按不同的字段作查询示例:
create table table1 (id int, ip varchar(15), city char(20));
 
insert into table1  values(1, '127.0.0.1', '深圳') ;
insert into table1  values(2, '127.0.0.2', '广州') ;
insert into table1  values(3, '127.0.0.2', '广州') ;
insert into table1  values(4, '127.0.0.2', '广州') ;
insert into table1  values(5, '127.0.0.2', '北京') ;
insert into table1  values(6, '127.0.0.4', '上海') ;
insert into table1  values(7, '127.0.0.4', '上海') ;
insert into table1  values(8, '127.0.0.4', '上海') ;
insert into table1  values(9, '127.0.0.7', '未知');
 
-- 按字段IP查询 
select * from table1 where id in 
-- 检索重复ip的纪录 
(select min(id) from table1 where ip in 
-- 求重复ip的其中一个id 
(select ip from table1 group by ip having count(1) >= 1) 
-- 取出重复的
ip group by ip ) ;


返回结果:
1	1	127.0.0.1          深圳                
2	2	127.0.0.2          广州                
3	6	127.0.0.4	         上海                
4	9	127.0.0.7	         未知   
           

create table table2 (id int, ip varchar(15), city char(20));
 
insert into table2 values( 1, '127.0.0.1', '深圳') ;
insert into table2 values( 2, '127.0.0.2', '广州') ;
insert into table2 values( 3, '127.0.0.2', '广州') ;
insert into table2 values( 4, '127.0.0.3', '北京') ;
insert into table2 values( 5, '127.0.0.3', '北京') ;
insert into table2 values( 6, '127.0.0.4', '上海') ;
insert into table2 values( 7, '127.0.0.4', '上海') ;
insert into table2 values( 8, '127.0.0.4', '上海') ;
insert into table2 values( 9, '127.0.0.7', '未知');



-- 按字段city查询 
select * from table1 where id in 
-- 检索重复city的纪录 
(select min(id) from table1 where city in 
-- 求重复city的其中一个id 
(select city from table1 group by city having count(1) >= 1) 
-- 取出重复的city 
group by city );


返回结果:
1	1	127.0.0.1         深圳                
2	2	127.0.0.2	         广州                
3	4	127.0.0.3	         北京                
4	6	127.0.0.4	         上海                
5	9	127.0.0.7         未知    
           

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值