1)2、刪除表中多余的重復記錄,根據(question_title)字段來判斷,只留有一個記錄代碼如下復制代碼de" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Mysql中查找并刪除重復數據的方法

系統 2389 0

(一)單個字段

1、查找表中多余的重復記錄,根據(question_title)字段來判斷

?代碼如下 復制代碼?
select * from questions where question_title in (select question_title from people group by question_title having count(question_title) > 1)
?

2、刪除表中多余的重復記錄,根據(question_title)字段來判斷,只留有一個記錄

?代碼如下 復制代碼?
delete from questions
where peopleId in (select peopleId from people group by peopleId having count(question_title) > 1)
and min(id) not in (select question_id from questions group by question_title having count(question_title)>1)

(二)多個字段

刪除表中多余的重復記錄(多個字段),只留有rowid最小的記錄

?代碼如下 復制代碼?
DELETE FROM questions WHERE (questions_title,questions_scope) IN (SELECT questions_title,questions_scope FROM questions GROUP BY questions_title,questions_scope HAVING COUNT(*) > 1) AND question_id NOT IN (SELECT MIN(question_id) FROM questions GROUP BY questions_scope,questions_title HAVING COUNT(*)>1)
?

用上述語句無法刪除,創建了臨時表才刪的,求各位達人解釋一下。

?代碼如下 復制代碼?
CREATE TABLE tmp AS SELECT question_id FROM questions WHERE (questions_title,questions_scope) IN (SELECT questions_title,questions_scope FROM questions GROUP BY questions_title,questions_scope HAVING COUNT(*) > 1) AND question_id NOT IN (SELECT MIN(question_id) FROM questions GROUP BY questions_scope,questions_title HAVING COUNT(*)>1);

DELETE FROM questions WHERE question_id IN (SELECT question_id FROM tmp);

DROP TABLE tmp;
?

(三) 存儲過程

?代碼如下 復制代碼?
declare @max integer,@id integer

declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) >; 1

open cur_rows

fetch cur_rows into @id,@max

while @@fetch_status=0

begin

select @max = @max -1

set rowcount @max

delete from 表名 where 主字段 = @id

fetch cur_rows into @id,@max

end

close cur_rows

set rowcount 0
?

例,

數據庫版本 Server version: 5.1.41-community-log MySQL Community Server (GPL)

例1,表中有主鍵(可唯一標識的字段),且該字段為數字類型

例1測試數據

?代碼如下 復制代碼?
/* 表結構 */
DROP TABLE IF EXISTS `t1`;
CREATE TABLE IF NOT EXISTS `t1`(
? `id` INT(1) NOT NULL AUTO_INCREMENT,
? `name` VARCHAR(20) NOT NULL,
? `add` VARCHAR(20) NOT NULL,
? PRIMARY KEY(`id`)
)Engine=InnoDB;

/* 插入測試數據 */
INSERT INTO `t1`(`name`,`add`) VALUES
('abc',"123"),
('abc',"123"),
('abc',"321"),
('abc',"123"),
('xzy',"123"),
('xzy',"456"),
('xzy',"456"),
('xzy',"456"),
('xzy',"789"),
('xzy',"987"),
('xzy',"789"),
('ijk',"147"),
('ijk',"147"),
('ijk',"852"),
('opq',"852"),
('opq',"963"),
('opq',"741"),
('tpk',"741"),
('tpk',"963"),
('tpk',"963"),
('wer',"546"),
('wer',"546"),
('once',"546");

SELECT * FROM `t1`;
+----+------+-----+
| id | name | add |
+----+------+-----+
|? 1 | abc? | 123 |
|? 2 | abc? | 123 |
|? 3 | abc? | 321 |
|? 4 | abc? | 123 |
|? 5 | xzy? | 123 |
|? 6 | xzy? | 456 |
|? 7 | xzy? | 456 |
|? 8 | xzy? | 456 |
|? 9 | xzy? | 789 |
| 10 | xzy? | 987 |
| 11 | xzy? | 789 |
| 12 | ijk? | 147 |
| 13 | ijk? | 147 |
| 14 | ijk? | 852 |
| 15 | opq? | 852 |
| 16 | opq? | 963 |
| 17 | opq? | 741 |
| 18 | tpk? | 741 |
| 19 | tpk? | 963 |
| 20 | tpk? | 963 |
| 21 | wer? | 546 |
| 22 | wer? | 546 |
| 23 | once | 546 |
+----+------+-----+
rows in set (0.00 sec)
?

查找id最小的重復數據(只查找id字段)

?代碼如下 復制代碼?
/* 查找id最小的重復數據(只查找id字段) */
SELECT DISTINCT MIN(`id`) AS `id`
FROM `t1`
GROUP BY `name`,`add`
HAVING COUNT(1) > 1;
+------+
| id?? |
+------+
|??? 1 |
|?? 12 |
|?? 19 |
|?? 21 |
|??? 6 |
|??? 9 |
+------+
rows in set (0.00 sec)
?


查找所有重復數據

?代碼如下 復制代碼?
/* 查找所有重復數據 */
SELECT `t1`.*
FROM `t1`,(
? SELECT `name`,`add`
? FROM `t1`
? GROUP BY `name`,`add`
? HAVING COUNT(1) > 1
) AS `t2`
WHERE `t1`.`name` = `t2`.`name`
? AND `t1`.`add` = `t2`.`add`;
+----+------+-----+
?

| id | name | add |
+----+------+-----+
|? 1 | abc? | 123 |
|? 2 | abc? | 123 |
|? 4 | abc? | www.111cn.net|
|? 6 | xzy? | 456 |
|? 7 | xzy? | 456 |
|? 8 | xzy? | 456 |
|? 9 | xzy? | 789 |
| 11 | xzy? | 789 |
| 12 | ijk? | 147 |
| 13 | ijk? | 147 |
| 19 | tpk? | 963 |
| 20 | tpk? | 963 |
| 21 | wer? | 546 |
| 22 | wer? | 546 |
+----+------+-----+
rows in set (0.00 sec)

更多詳細內容請查看: http://www.111cn.net/database/mysql/56725.htm

Mysql中查找并刪除重復數據的方法


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美日韩高清观看一区二区 | 中文国产成人久久精品小说 | 无毒不卡 | 欧美在线观看一区二区三 | 香蕉蕉亚亚洲aav综合 | 亚洲乱码视频 | 国产自产视频 | 成人影院午夜久久影院 | 色婷婷一区 | 国产婷婷色一区二区三区 | 99成人精品 | 色婷婷精品大全在线视频 | 欧美影院 | 国产精品久热 | 91精东果冻蜜桃星空麻豆 | 大片刺激免费播放视频 | 亚洲图片综合网 | 久久国产精品99久久久久久老狼 | 国产精品久久久久免费 | 国产精品久久久久激情影院 | 天天视频入口 | 狠狠亚洲婷婷综合色香 | 精品亚洲一区二区三区 | 青草视频在线 | swag系列国产精品 | 久久国产精品一区 | 国产区久久 | 欧美日本一本 | 亚洲欧美专区精品久久 | 亚洲图片另类 | 亚洲国产国产综合一区首页 | 免费国产小视频在线观看 | 免费观看欧美一级毛片 | 成人黄色一级毛片 | 欧美综合成人 | 日韩国产中文字幕 | 久久精品123| 亚洲精品高清在线 | 国产亚洲精品美女2020久久 | 欧美在线观看一区 | 老司机久久精品视频 |