oracle数据表删除重复数据

去重查询:

SQL> select * from flash_tbl;

ID VL

---------- --

10 I

11 J

12 K

13 L

14 M

15 N

16 O

17 P

18 Q

19 R

20 S

ID VL

---------- --

1 /

2 A

3 B

4 C

5 D

6 E

7 F

8 G

9 H

1 /

2 A

ID VL

---------- --

3 B

4 C

5 D

6 E

7 F

8 G

9 H

1 /

2 A

3 B

4 C

ID VL

---------- --

5 D

6 E

7 F

8 G

9 H

38 rows selected.

SQL> select distinct id,vl from flash_tbl;

ID VL

---------- --

11 J

14 M

7 F

8 G

20 S

4 C

5 D

12 K

16 O

17 P

1 /

ID VL

---------- --

10 I

13 L

2 A

3 B

15 N

18 Q

6 E

9 H

19 R

20 rows selected.

删除重复数据(两种方式,下列id为主键)

SQL> select * from flash_tbl a where rowid !=(select max(rowid) from flash_tbl b where a.id=b.id);    -----查出重复数据

SQL> delete from flash_tbl a where rowid !=(select max(rowid) from flash_tbl b where a.id=b.id);      -----删掉重复数据

-----------------------------------------------------------------------------------------------------------------------------------

SQL> select * from flash_tbl where id in (select id from flash_tbl group by id having count(id) > 1);    -----查出重复数据

SQL> delete from flash_tbl where id in (select id from flash_tbl group by id having count(id) > 1) and rowid not in (select min(rowid) from flash_tbl group by Id having count(Id)>1);     -----删掉重复数据

------------------------------------------------------------------------------------------------------------------------------------

补充:(表没主键时)

SQL> select * from flash_tbl  where rowid not in (select max(rowid) from flash_tbl group by id,vl);    -----查出重复数据

SQL> delete from flash_tbl  where rowid not in (select max(rowid) from flash_tbl group by id,vl); -----删掉重复数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

脑子进水养啥鱼?

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值