用SQL语句删除重复记录的2种方法.txt
来源:互联网 发布:清朝历史书知乎 编辑:程序博客网 时间:2024/04/29 08:57
问题:如何把具有相同字段的记录删除,只留下一条。
2. 写sql语句实现下列查询
(表)t
a b(列)
1 2
1 3
1 4
2 1
2 2
3 1
4 1
5 3
5 2
查询结果要求
a b
1 2
2 1
3 1
4 1
5 2
SQL结果:
select num1,min(num2)as num2 from t group by num1
例如:表test里有id,name字段,如果有name相同的记录只留下一条,其余的删除。name的内容不定,相同的记录数不定。
用SQL语句删除重复记录的四种方法:
方法1:
1、将重复的记录记入temp1表
select [标志字段id],count(*) into temp1 from [表名]group by [标志字段id]having count(*)>1
2、将不重复的记录记入temp1表
insert temp1select [标志字段id],count(*) from [表名]group by [标志字段id]having count(*)=1
3、作一个包含所有不重复记录的表
select * into temp2 from [表名]where 标志字段id in(select 标志字段id from temp1)
4、删除重复表:delete [表名]
5、恢复表
insert [表名]select * from temp2
6、删除临时表
drop table temp1drop table temp2
方法2:
declare @max integer,@id integerdeclare cur_rows cursor local for select id,count(*) from 表名 group by id having count(*) > 1open cur_rowsfetch cur_rows into @id,@maxwhile @@fetch_status=0beginselect @max = @max -1set rowcount @maxdelete from 表名 where id = @idfetch cur_rows into @id,@maxendclose cur_rowsset rowcount 0
注:set rowcount @max - 1表示当前缓冲区只容纳@max-1条记录,如果有十条重复的,就刪除10条,一定会留一条的。也可以写成delete from 表名。
2. 写sql语句实现下列查询
(表)t
a b(列)
1 2
1 3
1 4
2 1
2 2
3 1
4 1
5 3
5 2
查询结果要求
a b
1 2
2 1
3 1
4 1
5 2
SQL结果:
select num1,min(num2)as num2 from t group by num1
例如:表test里有id,name字段,如果有name相同的记录只留下一条,其余的删除。name的内容不定,相同的记录数不定。
用SQL语句删除重复记录的四种方法:
方法1:
1、将重复的记录记入temp1表
select [标志字段id],count(*) into temp1 from [表名]group by [标志字段id]having count(*)>1
2、将不重复的记录记入temp1表
insert temp1select [标志字段id],count(*) from [表名]group by [标志字段id]having count(*)=1
3、作一个包含所有不重复记录的表
select * into temp2 from [表名]where 标志字段id in(select 标志字段id from temp1)
4、删除重复表:delete [表名]
5、恢复表
insert [表名]select * from temp2
6、删除临时表
drop table temp1drop table temp2
方法2:
declare @max integer,@id integerdeclare cur_rows cursor local for select id,count(*) from 表名 group by id having count(*) > 1open cur_rowsfetch cur_rows into @id,@maxwhile @@fetch_status=0beginselect @max = @max -1set rowcount @maxdelete from 表名 where id = @idfetch cur_rows into @id,@maxendclose cur_rowsset rowcount 0
注:set rowcount @max - 1表示当前缓冲区只容纳@max-1条记录,如果有十条重复的,就刪除10条,一定会留一条的。也可以写成delete from 表名。
- 用SQL语句删除重复记录的2种方法.txt
- 用SQL语句删除重复记录的四种方法
- 用SQL语句删除重复记录的四种方法
- 用SQL语句删除重复记录的四种方法
- 四种SQL语句删除重复记录的方法
- 用SQL语句删除重复记录的四种好方法
- 用SQL语句删除重复记录的四种好方法
- sql语句删除重复的记录的方法
- sql语句删除重复的记录的方法
- sql语句删除重复的记录的方法
- sql语句删除重复的记录的方法
- SQL语句删除重复的记录的方法
- sql语句删除重复的记录的方法
- sql语句删除重复的记录的方法
- 用SQL删除重复记录的N种方法
- 用SQL删除重复记录的N种方法
- 用SQL删除重复记录的N种方法
- 用SQL删除重复记录的N种方法
- SQL 查询集合
- Impact 主题(四):碰撞
- 采用SQL交集查询解决复杂模式物业收费统计
- HTTP请求头、应答头概述
- Impact 主题(五):动画
- 用SQL语句删除重复记录的2种方法.txt
- RAC Crosschecking
- tcp tso
- 小波变换网文精粹:小波变换教程(十七)
- ORACLE执行计划的一些基本概念
- SQL 数据库操作
- android 常用intent
- 有类成员时,什么时候可以前置声明.什么时候需要#include .
- android游戏引擎andengine学习系列五:粒子发射器形成的超炫效果