如何删除表中重复的记录?
来源:互联网 发布:sql select where 编辑:程序博客网 时间:2024/04/27 17:17
由于多种原因,在表中可能会有一些重复的记录,有时需要删除这些重复的记录,那么,如何删除这些重复的记录呢?
现有如下的表:
SQL> create table a
2 (b number(1));
表已创建。
SQL> insert into a values (1);
已创建 1 行。
SQL> /
已创建 1 行。
SQL> /
已创建 1 行。
SQL> insert into a values (2);
已创建 1 行。
SQL> insert into a values (2);
已创建 1 行。
SQL> ed
已写入文件 afiedt.buf
1* insert into a values (3)
SQL> /
已创建 1 行。
SQL> select * from a;
B
----------
1
1
1
2
2
3
已选择6行。
SQL> alter table a add (c varchar(2));
表已更改。
SQL> select * from a;
B C
---------- --
1
1
1
2
2
3
已选择6行。
SQL> update a set c = b;
已更新6行。
SQL> select * from a;
B C
---------- --
1 1
1 1
1 1
2 2
2 2
3 3
已选择6行。
SQL> select b,c from a group by b, c;
B C
---------- --
1 1
2 2
3 3
通过这种方式,可以得到表中唯一的记录。
有多个字段时,全部为Group by 的分组条件。
另外,如果表中记录较多,时,最好不要直接用Delete方法删除。因为用这种方法Delete数据时,原有的存储空间是不会释放的。
可以用
INSERT INTO BACK_A AS select b,c from a group by b, c;
TRUNCATE TABLE A;
INSERT INTO A SELECT * FROM BACK_A ;
这样,即可以释放原有存储空间,同时又可以整理现在表的存储。
- 如何删除表中重复的记录?
- 如何删除数据表中重复的记录
- 如何删除数据库中重复的记录
- 如何删除数据库中重复的记录
- 如何删除数据库中重复的记录
- 如何删除表中重复记录?
- Oracle如何删除表中重复记录
- 如何删除一张表的重复记录
- 如何删除一张表重复的记录?
- 查找、删除表中重复的记录
- 如何查找、删除表中重复的记录
- 如何查找、删除表中重复的记录
- 删除表中重复的记录
- 如何查找、删除表中重复的记录
- 删除表中重复的记录
- 删除表中重复的记录
- 删除表中重复的记录!
- 删除表中重复记录的办法
- Windows精解:窗口类释疑
- 旧文重贴,悼念我的第一个电子邮箱:在同一个进程空间运行两个程序
- 多种流行效果JS代码
- 第一贴庆祝一下!
- 如何在一个窗口显示 一张表--JAVA
- 如何删除表中重复的记录?
- JSP 木马
- 短信应用设计备忘录
- 淘宝群发思路
- 在VisualAge v6.0 或 7.0 编译V5.3 MQ C++程序
- 有些无聊,来罗嗦两句
- 一个比较精确的“在线用户列表”统计功能
- 《WEB应用测试》笔记(二)
- 11月9日文件上传组件培训日记