用sql删除数据库重复的数据的方法
/***********************************************
两个意义上的重复记录:
1.是完全重复的记录,也即所有字段均重复的记录,
2.是部分关键字段重复的记录,比如username字段重复,
而其他字段不一定重复或都重复可以忽略,这类重复
问题通常要求保留重复记录中的第一条记录
************************************************/
/*1.数据完全重复(用到了一个临时表#Tmp)*/
CREATE TABLE admin1(
[username] [nvarchar](50) COLLATE Chinese_PRC_CI_AS NULL,
[password] [nvarchar](50) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
INSERT INTO admin1(username,password) VALUES('liyan','111')
INSERT INTO admin1(username,password) VALUES('liyan','111')
INSERT INTO admin1(username,password) VALUES('liyan','222')
INSERT INTO admin1(username,password) VALUES('liyan','222')
INSERT INTO admin1(username,password) VALUES('liyan','333')
select * from admin1
select distinct * into #Tmp from admin1
drop table admin1
select * into admin1 from #Tmp
drop table #Tmp
select * from admin1
/*2.某个字段重复(用到了2个临时表:Tmp1,Tmp2)*/
CREATE TABLE [dbo].[admin](
[id] [int] IDENTITY(1,1) NOT NULL,
[username] [nvarchar](50) COLLATE Chinese_PRC_CI_AS NULL,
[password] [nvarchar](50) COLLATE Chinese_PRC_CI_AS NULL,
CONSTRAINT [PK_admin] PRIMARY KEY CLUSTERED
(
[id] ASC
)WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]
INSERT INTO admin(username,password) VALUES('adminstrator','111')
INSERT INTO admin(username,password) VALUES('adminstrator','111')
INSERT INTO admin(username,password) VALUES('adminstrator','222')
INSERT INTO admin(username,password) VALUES('adminstrator','222')
INSERT INTO admin(username,password) VALUES('adminstrator','333')
INSERT INTO admin(username,password) VALUES('liyan','111')
INSERT INTO admin(username,password) VALUES('liyan','111')
INSERT INTO admin(username,password) VALUES('liyan','222')
INSERT INTO admin(username,password) VALUES('liyan','222')
INSERT INTO admin(username,password) VALUES('liyan','333')
if exists(select * from tempdb..sysobjects where id=object_id('tempdb..#Tmp1')) drop table #Tmp1
select id as autoid, * into #Tmp1 from admin
if exists(select * from tempdb..sysobjects where id=object_id('tempdb..#Tmp2')) drop table #Tmp2
select min(autoid) as autoid into #Tmp2 from #Tmp1 group by username,password
if exists(select * from dbo.sysobjects where id = object_id(N'admin') and OBJECTPROPERTY(id,N'IsUserTable') = 1) drop table admin
select id,username,password into admin from #Tmp1 where autoid in(select autoid from #tmp2)
=====================================================
下面的是引用网上的一篇文章(http://tb.blog.csdn.net/TrackBack.aspx?PostId=1530926)
关于使用sql删除数据库重复的数据的方法整理:
1.数据完全重复
通过一个临时表过渡一下
insert into table1 select distinct field from table
drop table table
insert into table select * from table1
2.某个字段重复
这个在网上有很多相关的解决方法,较常见的有
delete from table where id not in (select min(id) from table group by name)
delete from table where field in (select field from table group by field having count(*) > 1)
上面的方法在删除小数量级的数据时还有用,当一旦处理的数据是几十万或者更多时就出问题了,一般的机器估计一运行就马上给费了。其实稍有点常识的算一算就知道这样的语句会有多大的运算量了,它的运算量至少是以乘方的形式递增的,想想就恐怖。
我在这里主要是要给出对于大数量级的表的重复数据删除的解决方案,其实也很简单,也是利用了一个过渡表来实现
insert in tabletemp select * from table
delete from table as a where a.id > (select min(b.id) from table1 as b where b.field=a.field)
drop table tabletemp
这样利用了数据库的索引的优势,大大的减少运算量
========================================
SQL如何删除重复的数据行- -
delete from table where id in (
select max(id) from table group by name having count(*)>1
)--删除重复记录中ID最大的一条(如果有2条以上的重复记录则需多次执行)
如果table数据完全一样,可以先将数据导入到一个临时表内
或
delete from table where id not in (
select min(id) from table group by name
)--只保留重复记录的第一条(id最小的一条)
太少了..加点其它的内容
CREATE PROCEDURE 存储过程名 --执行动态SQL语句
(
@num int
)
AS
declare @string nvarchar(100)
set @string='SELECT TOP '+ CAST (@num as nvarchar) +' * FROM 表名'
exec (@string)
=====================================
select ID,NAME from house1 where name='中凯' and roomtype='双人间' and startdate>='2007-5-25' and id in(select min(id) from group by name)
name相同时id小的出现
======================
一般就是distinct , group by , #tempTable,
当然借助index会更快些
用sql删除数据库重复的数据的方法的更多相关文章
- sql删除数据库重复字段的行
要保留的数据: WITH summary AS ( SELECT p.id, p.customer, p.total, ROW_NUMBER() OVER(PARTITION BY p.custome ...
- sql删除多余重复的数据只保留一条
delete from people where peopleName in (select peopleName from people group by peopleName ...
- SQL DISTINCT去掉重复的数据统计方法【转】
SELECT指令让我们能够读取表格中一个或数个栏位的所有资料.这将把所有的资料都抓出,无论资料值有无重复.在资料处理中,我们会经常碰到需要找出表格内的不同资料值的情况.换句话说,我们需要知道这个表格/ ...
- 删除sql server中重复的数据
原文:删除sql server中重复的数据 with list_numbers as( select Name, AuthorOrTime, Url, Price, EstimatePrice, Si ...
- SQL跨数据库复制表数据
SQL跨数据库复制表数据 不同服务器数据库之间的数据操作 不同数据库之间复制表的数据的方法: 当表目标表存在时: insert into 目的数据库..表 select * from 源数据库.. ...
- SQL删除数据库里所有表的外键,同时删除所有用户表
SQL删除数据库里所有表的外键,同时删除所有用户表 删除所有的用户表的外键,直接将下面的代码拷贝到数据库里执行即可: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 ...
- sql server2008数据库复制实现数据同步常见问题
sql server2008数据库复制实现数据同步常见问题 在原作者基础上追加 sql server2008数据库复制实现数据同步常见问题 23.发布 'xx' 的并发快照不可用,因为该快照尚未完全生 ...
- sql server 数据库复制实现数据同步常见问题(不定期更新)
sql server2008数据库复制实现数据同步常见问题 在原作者基础上追加 sql server2008数据库复制实现数据同步常见问题 23.发布 'xx' 的并发快照不可用,因为该快照尚未完全生 ...
- PHP MySQL Delete删除数据库中的数据
PHP MySQL Delete DELETE 语句用于从数据库表中删除行. 删除数据库中的数据 DELETE FROM 语句用于从数据库表中删除记录. 语法 DELETE FROM table_na ...
随机推荐
- 【转】弹出USB大容量存储设备时出问题的解决方法
原文链接 如下图所示,这个问题,相信很多人都有遇到过,而且经常难以解决,试了很多方法都无效.到最后,只能抱着侥幸的心理直接拔出,如果运气好,可能没有事,如果运气不好,你的U盘或者移动硬盘就要从此报废了 ...
- Web基础了解版09-Cookie-Session
Cookie Cookie 是一种服务器发送给浏览器以键值对形式存储小量信息的技术. 当浏览器首次请求服务器时,服务器会将一条信息封装成一个Cookie发送给浏览器,浏览器收到Cookie,会将它保存 ...
- idea激活,使用破解补丁无需注册码
idea激活,使用破解补丁无需注册码 2017年08月19日 10:57:54 标签: idea / 破解 / 补丁 / 软件 / 13891 编辑 删除 idea激活,JetBrain旗下软件激活 ...
- 基于Goolgle最新NavigationDrawer实现全屏水平平移
常见实现App 上面侧边栏菜单之前使用SlidingMenu,现在发现Goolgle原生NavigationDrawer也挺好用.但是细心的开发者们发现NavigationDrawer没有类似Slid ...
- selenium webdriver 操作RadioButton
@Test public void testRadio() { WebDriver driver = ExplorerBase.IESetting(); try { Thread.sleep(500) ...
- (踩过的坑)使用Github Page搭建个人博客
最近需要搭建一个网站,作为导航网址,但是自己的域名备案还要等上几天,就想着有没有别的办法来搭建一个公网可以访问的网站. Github Page的话是一个github个人主页,完全适合用来搭建普通网站. ...
- 重新学习CSS,认识CSS3中的属性
之前学css,觉得会改个样式就不错了,直到现在,在做前端开发的时候,才发现自己的前端页面是有多垃圾,而且还不知道该怎么适应各个浏览器,总是很“词穷”,最近是想着好久没去慕课上面了,于是就报着逛一逛的心 ...
- 我的学习经历——Linux系统入门教程
我想把最近学习Linux的经验和过程分析出来,当时是在上大三,是学生一枚,以前对开源也没有什么特殊的认识,只觉得很高深,不明觉厉的东西,在当时因为学校要参加职业技能大赛,其中有一团体性质的比赛,几个同 ...
- Android 记住密码和自动登录界面的实现(SharedPreferences 的用法)
原文:http://blog.csdn.net/liuyiming_/article/details/7704923 SharedPreferences介绍: SharedPreferences是An ...
- Android studio For Mac 安装
简介: Google在2013的I/O开发者大会上正式对外宣布Android Studio将作为Android开发的主要IDE,它是基于IntelliJ IDEA打造的一款专门开发Android的神器 ...