新聞中心
在Oracle數(shù)據(jù)庫中,經(jīng)常有重復記錄的情況出現(xiàn),"Oracle重復記錄"有兩個意義上的Oracle重復記錄,一是完全重復的記錄,也即所有字段均重復的記錄,二是部分關鍵字段重復的記錄,比如Name字段重復,而其他字段不一定重復或都重復可以忽略。

九江網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、APP開發(fā)、響應式網(wǎng)站開發(fā)等網(wǎng)站項目制作,到程序開發(fā),運營維護。成都創(chuàng)新互聯(lián)從2013年成立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設就選成都創(chuàng)新互聯(lián)。
1、對于***種Oracle重復記錄,比較容易解決,使用select distinct * from tableName 就可以得到無重復記錄的結果集?! ?/p>
如果該表需要刪除重復的記錄(重復記錄保留1條),可以按以下方法刪除
select distinct * into #Tmp
from tableNamedrop table tableNameselect * into tableName
from #Tmpdrop table #Tmp
發(fā)生這種重復的原因是表設計不周產(chǎn)生的,增加唯一索引列即可解決?! ?/p>
2、這類Oracle重復記錄通常要求保留重復記錄中的***條記錄,操作方法如下
假設有重復的字段為Name,Address,要求得到這兩個字段唯一的結果集
select identity(int,1,1) as autoID, * into #Tmp
from tableNameselect min(autoID)
as autoID into #Tmp2
from #Tmp group by Name,autoIDselect *
from #Tmp where autoID in(select autoID from #tmp2)
***一個select即得到了Name,Address不重復的結果集(但多了一個autoID字段,實際寫時可以寫在select子句中省去此列)
【編輯推薦】
oracle查詢當前時間的實現(xiàn)
帶您了解Oracle層次查詢
帶您深入了解Oracle臨時表
Oracle with語句的用法
常見的ORACLE數(shù)據(jù)類型介紹
當前名稱:教您如何刪除Oracle重復記錄
本文網(wǎng)址:http://m.fisionsoft.com.cn/article/dpsodpd.html


咨詢
建站咨詢
