數(shù)據(jù)庫學習(六)

顧穎17021223250

轉載自https://blog.csdn.net/luyaran/article/details/80928666

【嵌牛導讀】:mysql使用技巧之比較兩個表是否有不同的數(shù)據(jù)

【嵌牛鼻子】:MySQL比較兩個表的數(shù)據(jù)技巧

【嵌牛提問】:如何新建兩張表?怎么比較兩張表的數(shù)據(jù)中的不同值?

【嵌牛正文】:

在數(shù)據(jù)遷移中,我們經(jīng)常需要比較兩個表,以便在一個表中標識另一個表中沒有相應記錄的記錄。

例如,我們有一個新的數(shù)據(jù)庫,其架構與舊數(shù)據(jù)庫不同。我們的任務是將所有數(shù)據(jù)從舊數(shù)據(jù)庫遷移到新數(shù)據(jù)庫,并驗證數(shù)據(jù)是否正確遷移。要檢查數(shù)據(jù),我們必須比較兩個表,一個在新數(shù)據(jù)庫中,一個在舊數(shù)據(jù)庫中,并標識不匹配的記錄。

假設有兩個表:t1和t2。使用以下步驟比較兩個表,并確定不匹配的記錄,按著常用的思路就是,我們先查t1,完事呢,拿著數(shù)據(jù)結果集來循環(huán),一條一條的去另一張表中查詢,能查到數(shù)據(jù),就是正確的,查詢不到,就是數(shù)據(jù)有丟失的現(xiàn)象。

如果真的這樣的話,那你可就真的是啊,too young too simple了。這次呢,咱們來介紹一個比較簡單的數(shù)據(jù)對比方案,那就是使用union all關聯(lián)兩張表,完事使用臨時表或者說派生表的方式來進行數(shù)據(jù)對比。先來看下union all的sql實例吧:

SELECT t1.pk, t1.c1

FROM t1

UNION ALL

SELECT t2.pk, t2.c1

FROM t2

完事咱們就先來建立兩張表,再插入一些數(shù)據(jù),完事就可以進行測試了,先來看建表:

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;

運行之后當然是沒有任何返回數(shù)據(jù)的,因為它們是沒有什么差別的。不著急哈,咱們再來在t2表中插入一行數(shù)據(jù):

INSERT INTO t2(title,note)

VALUES('new row 4','new');

完事我們再次比較兩個表中的title列的值,因為新行是不匹配的行將會返回,我們來看下結果:

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

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容