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

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


咨詢
建站咨詢
