mysql實(shí)用技巧之比較兩個表是否有不同數(shù)據(jù)的方法分析
本文實(shí)例講述了mysql比較兩個表是否有不同數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
在數(shù)據(jù)遷移中,我們經(jīng)常需要比較兩個表,以便在一個表中標(biāo)識另一個表中沒有相應(yīng)記錄的記錄。
例如,我們有一個新的數(shù)據(jù)庫,其架構(gòu)與舊數(shù)據(jù)庫不同。我們的任務(wù)是將所有數(shù)據(jù)從舊數(shù)據(jù)庫遷移到新數(shù)據(jù)庫,并驗(yàn)證數(shù)據(jù)是否正確遷移。要檢查數(shù)據(jù),我們必須比較兩個表,一個在新數(shù)據(jù)庫中,一個在舊數(shù)據(jù)庫中,并標(biāo)識不匹配的記錄。
假設(shè)有兩個表:t1和t2。使用以下步驟比較兩個表,并確定不匹配的記錄,按著常用的思路就是,我們先查t1,完事呢,拿著數(shù)據(jù)結(jié)果集來循環(huán),一條一條的去另一張表中查詢,能查到數(shù)據(jù),就是正確的,查詢不到,就是數(shù)據(jù)有丟失的現(xiàn)象。
如果真的這樣的話,那你可就真的是啊,too young too simple了。這次呢,咱們來介紹一個比較簡單的數(shù)據(jù)對比方案,那就是使用union all關(guān)聯(lián)兩張表,完事使用臨時表或者說派生表的方式來進(jìn)行數(shù)據(jù)對比。先來看下union all的sql實(shí)例吧:
SELECT t1.pk, t1.c1 FROM t1 UNION ALL SELECT t2.pk, t2.c1 FROM t2
完事咱們就先來建立兩張表,再插入一些數(shù)據(jù),完事就可以進(jìn)行測試了,先來看建表:
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');
再來在t2中插入數(shù)據(jù):
INSERT INTO t2(title) VALUES('row 1'),('row 2'),('row 3');
好,咱們接下來就是要使用派生表的方式來對比數(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)然是沒有任何返回數(shù)據(jù)的,因?yàn)樗鼈兪菦]有什么差別的。不著急哈,咱們再來在t2表中插入一行數(shù)據(jù):
INSERT INTO t2(title,note) VALUES('new row 4','new');
完事我們再次比較兩個表中的title列的值,因?yàn)樾滦惺遣黄ヅ涞男袑祷?,我們來看下結(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)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。
相關(guān)文章
MySQL運(yùn)維實(shí)戰(zhàn)使用RPM進(jìn)行安裝部署
這篇文章主要為大家介紹了MySQL運(yùn)維實(shí)戰(zhàn)使用RPM進(jìn)行安裝部署實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Ubuntu安裝Mysql+啟用遠(yuǎn)程連接的完整過程
這篇文章主要介紹了Ubuntu如何安裝Mysql+啟用遠(yuǎn)程連接,用ssh客戶端或者云服務(wù)器廠家提供的網(wǎng)頁版控制臺都行,只要你能連上服務(wù)器就行,需要的朋友可以參考下2022-06-06Linux虛擬機(jī)下mysql 5.7安裝配置方法圖文教程
這篇文章主要為大家詳細(xì)介紹了Linux虛擬機(jī)下mysql 5.7安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01MySQL查詢優(yōu)化:連接查詢排序limit(join、order by、limit語句)介紹
兩張表連接查詢并limit,SQL效率很高,但是加上order by以后,語句的執(zhí)行時間變的巨長,效率巨低,接下來為大家介紹下連接查詢排序limit2013-04-04