Print

数据库表里如何删除重复数据

问:sql中如何删除一个表中重复的记录?
  1. 答:sql中删除一个表中的重复记录可以采用如下步骤: 
    1、把a_dist表的记录用distinct去重,结果放到临时表中。
    select  distinct * into #temp from a_dist;
    2、把a_dist表的记录全部删除。
    delete  from a_dist;
    3、把临时表中的数据信息导进到a_dist表中,并删除临时表。
    insert  into a_dist select * from #temp;
    drop table #temp;
    扩展资料:
    SQL (结构化查询语言)是用于执行查询的语法。在数据库上执行的大部分工作都由 SQL 语句完成。SQL 语言包含用于更新、插入和删除记录的语法。
    增删改查指令构成了 SQL 的 DML 部分:
    SELECT - 从数据库表中获取数据
    UPDATE - 更新数据库表中的数据
    DELETE - 从数据库表中删除数据
    INSERT INTO - 向数据库表中插入数据
问:在SQL中怎么删除两个表中相同的数据
  1. 答:1,首先创建一个表,并在表中插入重复的记录,如下图所示。
    2,插入好以后就看见表中已经有重复的数据了,如下图所示。
    3,接下来在删除之前我们记得一定先备份,如下图所示。
    4,然后排除重复的记录可以通过distinct字段设置,如下图所示,然后将去重的数据插入到新表中。
    5,接着看到数据表下面多出来一个刚建的新表,如下图所示。
    6,最后打开新表,就可以看到重复的数据都没有了,如下图所示。
问:如何删除数据库中的重复数据
  1. 答:有两个意义上的重复记录
    ①完全重复的记录,也即所有字段均重复的记录。
    ②部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。
    1、对于第一种重复,比较容易解决,使用
    select distinct * from tableName
    这样就可以得到无重复记录的结果集。然后通过临时表实现对数据的维护。
    select distinct * into #Tmp from tableName
    drop table tableName
    select * into tableName from #Tmp
    drop table #Tmp
    #Tmp为什么系统参数,tableName为要操作的表名。
    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子句中省去此列)

本文来源: https://www.lunwen80.cn/article/7011036d792abcaac1d75655.html