本文實(shí)例講述了MySQL比較兩個(gè)表是否有不同數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
創(chuàng)新互聯(lián)公司-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比寧海網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式寧海網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋寧海地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴。
在數(shù)據(jù)遷移中,我們經(jīng)常需要比較兩個(gè)表,以便在一個(gè)表中標(biāo)識(shí)另一個(gè)表中沒(méi)有相應(yīng)記錄的記錄。
例如,我們有一個(gè)新的數(shù)據(jù)庫(kù),其架構(gòu)與舊數(shù)據(jù)庫(kù)不同。我們的任務(wù)是將所有數(shù)據(jù)從舊數(shù)據(jù)庫(kù)遷移到新數(shù)據(jù)庫(kù),并驗(yàn)證數(shù)據(jù)是否正確遷移。要檢查數(shù)據(jù),我們必須比較兩個(gè)表,一個(gè)在新數(shù)據(jù)庫(kù)中,一個(gè)在舊數(shù)據(jù)庫(kù)中,并標(biāo)識(shí)不匹配的記錄。
假設(shè)有兩個(gè)表:t1和t2。使用以下步驟比較兩個(gè)表,并確定不匹配的記錄,按著常用的思路就是,我們先查t1,完事呢,拿著數(shù)據(jù)結(jié)果集來(lái)循環(huán),一條一條的去另一張表中查詢,能查到數(shù)據(jù),就是正確的,查詢不到,就是數(shù)據(jù)有丟失的現(xiàn)象。
如果真的這樣的話,那你可就真的是啊,too young too simple了。這次呢,咱們來(lái)介紹一個(gè)比較簡(jiǎn)單的數(shù)據(jù)對(duì)比方案,那就是使用union all關(guān)聯(lián)兩張表,完事使用臨時(shí)表或者說(shuō)派生表的方式來(lái)進(jìn)行數(shù)據(jù)對(duì)比。先來(lái)看下union all的sql實(shí)例吧:
SELECT t1.pk, t1.c1 FROM t1 UNION ALL SELECT t2.pk, t2.c1 FROM t2
完事咱們就先來(lái)建立兩張表,再插入一些數(shù)據(jù),完事就可以進(jìn)行測(cè)試了,先來(lái)看建表:
CREATE TABLE t1( id int auto_increment primary key, title varchar(255) ); CREATE TABLE t2( id int auto_increment primary key, title varchar(255), note varchar(255) );
完事先在t1中插入數(shù)據(jù):
INSERT INTO t1(title) VALUES('row 1'),('row 2'),('row 3');
再來(lái)在t2中插入數(shù)據(jù):
INSERT INTO t2(title) VALUES('row 1'),('row 2'),('row 3');
好,咱們接下來(lái)就是要使用派生表的方式來(lái)對(duì)比數(shù)據(jù)了哦:
SELECT id,title FROM ( SELECT id, title FROM t1 UNION ALL SELECT id,title FROM t2 ) tbl GROUP BY id, title HAVING count(*) = 1 ORDER BY id;
運(yùn)行之后當(dāng)然是沒(méi)有任何返回?cái)?shù)據(jù)的,因?yàn)樗鼈兪菦](méi)有什么差別的。不著急哈,咱們?cè)賮?lái)在t2表中插入一行數(shù)據(jù):
INSERT INTO t2(title,note) VALUES('new row 4','new');
完事我們?cè)俅伪容^兩個(gè)表中的title列的值,因?yàn)樾滦惺遣黄ヅ涞男袑?huì)返回,我們來(lái)看下結(jié)果:
mysql> SELECT id,title FROM ( SELECT id, title FROM t1 UNION ALL SELECT id,title FROM t2 ) tbl GROUP BY id, title HAVING count(*) = 1 ORDER BY id; +----+-----------+ | id | title | +----+-----------+ | 4 | new row 4 | +----+-----------+ 1 row in set
好啦,這次小技巧就到這里了哦。
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《MySQL查詢技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過(guò)程技巧大全》及《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總》
希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。
本文名稱:mysql實(shí)用技巧之比較兩個(gè)表是否有不同數(shù)據(jù)的方法分析
分享地址:http://chinadenli.net/article30/gdosso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、網(wǎng)站維護(hù)、網(wǎng)站收錄、域名注冊(cè)、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)