您好,登錄后才能下訂單哦!
這篇文章給大家介紹MySQL數(shù)據(jù)庫(kù)中怎么查找刪除重復(fù)行,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
當(dāng)你對(duì)b字段排序(分組),相同值的c被分到不同的組,因此不能用COUNT(DISTINCT c)來(lái)計(jì)算大小。COUNT()之類的內(nèi)部函數(shù)只作用于同一個(gè)分組,對(duì)于不同分組的行就無(wú)能為力了。類似,如果排序的是c字段,相同值的b也會(huì)分到不同的組,無(wú)論如何是不能達(dá)到我們的目的的。
幾種正確的方法
也許最簡(jiǎn)單的方法是分別對(duì)某個(gè)字段查找重復(fù)行,然后用UNION拼在一起,像這樣:
select b as value, count(*) as cnt, 'b' as what_col from a_b_c group by b having count(*) > 1 union select c as value, count(*) as cnt, 'c' as what_col from a_b_c group by c having count(*) > 1; +-------+-----+----------+ | value | cnt | what_col | +-------+-----+----------+ | 1 | 3 | b | | 2 | 3 | b | | 3 | 3 | b | | 1 | 3 | c | | 2 | 3 | c | | 3 | 3 | c | +-------+-----+----------+
輸出what_col字段為了提示重復(fù)的是哪個(gè)字段。另一個(gè)辦法是使用嵌套查詢:
select a, b, c from a_b_c where b in (select b from a_b_c group by b having count(*) > 1) or c in (select c from a_b_c group by c having count(*) > 1); +----+------+------+ | a | b | c | +----+------+------+ | 7 | 1 | 1 | | 8 | 1 | 2 | | 9 | 1 | 3 | | 10 | 2 | 1 | | 11 | 2 | 2 | | 12 | 2 | 3 | | 13 | 3 | 1 | | 14 | 3 | 2 | | 15 | 3 | 3 | +----+------+------+
這種方法的效率要比使用UNION低許多,并且顯示每一重復(fù)的行,而不是重復(fù)的字段值。還有一種方法,將自己跟group的嵌套查詢結(jié)果聯(lián)表查詢。寫法比較復(fù)雜,但對(duì)于復(fù)雜的數(shù)據(jù)或者對(duì)效率有較高要求的情況,是很有必要的。
select a, a_b_c.b, a_b_c.c from a_b_c left outer join ( select b from a_b_c group by b having count(*) > 1 ) as b on a_b_c.b = b.b left outer join ( select c from a_b_c group by c having count(*) > 1 ) as c on a_b_c.c = c.c where b.b is not null or c.c is not null
關(guān)于MySQL數(shù)據(jù)庫(kù)中怎么查找刪除重復(fù)行就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。