数据库去掉重复的数据
2023-01-20
阅读(626)

问:sql中如何删除一个表中重复的记录?
- 答: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 - 向数据库表中插入数据
问:如何删除数据库中的重复数据
- 答:有两个意义上的重复记录
①完全重复的记录,也即所有字段均重复的记录。
②部分关键字段重复的记录,比如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子句中省去此列)
问:oracle查询出来的数据如何消除重复数据
- 答:oracle查询出来的数据消除重复数据的具体步骤如下:
1、首先我们查看表中重复的数据。
2、然后我饿美女使用distinct去除函数查询出去掉重复后的数据。
3、然后我们创建新表把去掉重复的数据插入到新表中。
4、最后使用truncate清空原表中的数据。
5、再向原表中插入新表中重复的数据,即可达到去重复数据的效果。 - 答:在select关键字的后边加上distinct字段就可以额
- 答:SELECT distinct "PAT_MASTER_INDEX"."PATIENT_ID", "PAT_MASTER_INDEX"."NAME", "INP_PAYMENTS_MONEY"."PAYMENT_AMOUNT", "INP_PAYMENTS_MONEY"."MONEY_TYPE", "INP_SETTLE_MASTER"."CHARGES", "INP_SETTLE_MASTER"."RCPT_NO", "INP_SETTLE_MASTER"."OPERATOR_NO" FROM "INP_PAYMENTS_MONEY", "INP_SETTLE_MASTER", "PAT_MASTER_INDEX" WHERE ( "INP_PAYMENTS_MONEY"."RCPT_NO" = "INP_SETTLE_MASTER"."RCPT_NO" ) and ( "INP_SETTLE_MASTER"."PATIENT_ID" = "PAT_MASTER_INDEX"."PATIENT_ID" )
- 答:在你需要去掉重复数据的字段前加上distinct
select distinct PATIENT_ID from xxxx