您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

SQL Server中删除重复记录的SQL语句

2024/2/26 21:39:55发布11次查看
本文章来详细的给各位朋友来介绍sql server中删除重复记录的sql语句方法总结,一般情况下,我们会有两种情况的删除操作,一种是完全重复的记录,所有字段都重复的情况,另一种是部分关键字段重复的记录,其他字段不重复,或重复但可以忽略。
方法:
 代码如下 复制代码
distinct * into #tmp from tablename  drop table tablename  select * into tablename from #tmp
drop table # tmp
常有时候遇到需要删除sql server中的重复记录,这里有一些常用的删除重复记录的sql,
最常用的 t-sql 语句:
 代码如下 复制代码
delete from [dbo].[mytable] where 主键 not in
    (select max(主键) from [dbo].[mytable] group by 列1, 列2, 列3)从 sql server 2005 以后,用 cte:
with tmporderdtable
as
(
  select 
    groupid = row_number() over (partition by 列1, 列2, 列3 order by 主键)
  from
    [dbo].[mytable]
)
delete from tmporderdtable where groupid > 1
为了提高效率可以先开启单人存取模式,删除完再恢复多人存取模式:
# 开启单人存取模式 
 代码如下 复制代码
use [master] 
alter database [mydb] set single_user with rollback immediate
# 开启多人存取模式 
use [master] 
alter database [mydb] set multi_user with rollback immediaterelated posts
sql存储过程删除
 代码如下 复制代码
declare @max integer,@id integer
declare cur_rows cursor local for select 主字段,count(*) from 表名 主字段 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
a:保留id最大的行,删除其它行  
方法1  
 代码如下 复制代码
delete   [user]   from   [user]   t    
  inner   join(select   name,max(id)   as   id   from   [user]   group   by   name)   a  
  on   t.name   =   a.name   and   t.id      a.id
b:保留id最小的行,删除其它行  
方法1  
 代码如下 复制代码
  delete   [user]   from   [user]   t    
  inner   join(select   name,min(id)   as   id   from   [user]   group   by   name)   a  
  on   t.name   =   a.name   and   t.id      a.id
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product