问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

sql server语句中重复的数据怎么删除

发布网友 发布时间:2022-04-07 23:24

我来回答

2个回答

懂视网 时间:2022-04-08 03:45

代码如下:
declare @max integer,@id integer
declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) > 1
open cur_rows
fetch cur_rows into @id,@max
while @@fetch_status=0
begin
select @max = @max -1
set rowcount @max
delete from 表名 where 主字段 = @id
fetch cur_rows into @id,@max
end
close cur_rows
set rowcount 0


方法二
有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。
1、对于第一种重复,比较容易解决,使用

复制代码 代码如下:
select distinct * from tableName


就可以得到无重复记录的结果集。
如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除

复制代码 代码如下:
select distinct * into #Tmp from tableName
drop table tableName
select * into tableName from #Tmp
drop table #Tmp


发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。
2、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下
假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集

复制代码 代码如下:
select identity(int,1,1) as autoID, * into #Tmp from tableName
select min(autoID) as autoID into #Tmp2 from #Tmp group by Name,autoID
select * from #Tmp where autoID in(select autoID from #tmp2)


最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列)

前段时间写的如何删除sql数据库中重复记录是针对sql数据库的,最近发现有人需求access数据库删除重复记录的语句,发上来与大家分享。

复制代码 代码如下:
delete from 表名 where 重复字段名 in (select 重复字段名 from 表名 group by 重复字段名 having count(重复字段名) > 1) and id not in (select min(id) from 表名 group by 重复字段名 having count(重复字段名 )>1)

教你几种在SQLServer中删除重复数据方法(转)

标签:

热心网友 时间:2022-04-08 00:53

1、必须保证表中有主键或者唯一索引,或者某列数据不能重复。只有这样,才可能使用一句SQL来实现。否则只能考虑其它办法。下面的语句,假定BB列是不重复的,删除后保存BB列值最大的那条记录。
delete from 表
where aa in (select aa from 表 group by aa having count(aa) > 1) and
bb not in (select max(bb) from 表 group by aa having count(aa) > 1);

2、有多种写法:
delete A from B where A.AA = B.AA
delete A from A,B where A.AA = B.AA
delete A where AA in (select AA from B)

3、使用into关键字:
select * into 新表名 from 原表

4、取数据前3位,字段必须是类似char类型,使用类似substring这样的函数(SYBASE是substring,ORACLE是substr):
select substring(字段,1,3) from 表名
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
14岁每天做多少蹲起和提踵不影响长高 每天晚上提踵来练弹跳会影响长高吗? 提踵和练肌肉会不会长不高? 提踵(抬脚跟)训练会影响长个吗 求高人指点 提踵 会不会影响身高的增长? 我现在15岁 提踵有利于长高吗 提踵影响长高吗 win10可不可以玩盗版的中2,帝战,拿战 沧州蓝海光伏设备有限公司怎么样? 为什麽女巫要骑扫帚不骑板凳。。。 济南治慢性前列腺炎治疗的男科医院 济南治疗慢性前列腺炎最好的医院 ps4手柄可以直接通过蓝牙连pc吗?用steam的话 济南前列腺炎医院? ps4手柄到底怎么连steam客户端 济南男科医院排名 济南男科医院哪家最好?济南专业男科医院 求助ps4手柄连PC端steam羞辱2怎么连 济南治疗前列腺最好的医院 济南哪家医院看前列腺好 怎么用ps4手柄无线连接steam HOUSEHOLD是什么牌电子炉盘? 得物上卖的浪琴手表是正品吗- 问一问 最妈炉盘是什么牌子的 炉盘的整机和易损部件分别是什么 燃气灶sn是什么意思 热水壶炉盘是什么材质? 请问电炉子的炉盘是用什么材料做的? 燃气灶熄保原理是什么? 电炉炉盘是什么做的,什么材料 燃气灶只有最里面一圈有火是什么原因? 做近视眼手术全飞秒好还是半飞秒好? 全飞秒治疗近视眼要多少钱? 买房贷款44万三十年还清 按本金还贷 每个月还多少钱? 我贷了44万,30年,年利率5%,每月还多少,等额本金和等额本息各还多少 贷款44万30年利息是5.39等额本金还款多少一月? 贷款44万年利息4.018三十年多少钱 贷款44万30年利率6.660%正常吗? 阴沟是指哪里 cf女角色阴沟透视图 和女性发生性后2一3天,寇阴沟起了水泡后来就白色的浓样,用药一星期好了,跟一前皮肤一样了,有半个多... 女生阴沟那长了两个白色小白疙瘩跟小泡泡似的是怎么回事? 《致命美色[快穿]》txt下载在线阅读全文,求百度网盘云资源 是什么导致他们不能逆袭成功? 庸二次元是什么意思? 求女主男友力爆棚的小说,可苏但不要蕾丝,国民男友,另类影后已看, 为什么送的礼物少了就会被骂的很惨因为关注快手主播了? 怎么评价电影《银魂》? 少女前线求AR小队全剧情 《博人传》佐助穿越,鼬见到他为何直骂他蠢? 血源诅咒神父boss怎么打