博客
关于我
oracle数据表删除重复数据
阅读量:590 次
发布时间:2019-03-11

本文共 1295 字,大约阅读时间需要 4 分钟。

去重查询:

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.

删除重复数据(两种方式)

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);     -----删掉重复数据

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

 

转载地址:http://advtz.baihongyu.com/

你可能感兴趣的文章
MySQL 索引深入解析及优化策略
查看>>
MySQL 索引的面试题总结
查看>>
mysql 索引类型以及创建
查看>>
MySQL 索引连环问题,你能答对几个?
查看>>
Mysql 索引问题集锦
查看>>
Mysql 纵表转换为横表
查看>>
mysql 编译安装 window篇
查看>>
mysql 网络目录_联机目录数据库
查看>>
MySQL 聚簇索引&&二级索引&&辅助索引
查看>>
Mysql 脏页 脏读 脏数据
查看>>
mysql 自增id和UUID做主键性能分析,及最优方案
查看>>
Mysql 自定义函数
查看>>
mysql 行转列 列转行
查看>>
Mysql 表分区
查看>>
mysql 表的操作
查看>>
mysql 视图,视图更新删除
查看>>
MySQL 触发器
查看>>
mysql 让所有IP访问数据库
查看>>
mysql 记录的增删改查
查看>>
MySQL 设置数据库的隔离级别
查看>>