濮阳杆衣贸易有限公司

主頁 > 知識庫 > mysql實用技巧之比較兩個表是否有不同數據的方法分析

mysql實用技巧之比較兩個表是否有不同數據的方法分析

熱門標簽:外呼系統(tǒng)電銷受騙 銷售語音電話機器人 400電話申請信用卡 走過哪個省地圖標注 在哪里申請400電話 常州網絡外呼系統(tǒng)開發(fā) 巫師三血與酒地圖標注 萊西市地圖標注 安徽ai電話電銷機器人有效果嗎

本文實例講述了mysql比較兩個表是否有不同數據的方法。分享給大家供大家參考,具體如下:

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

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

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

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

SELECT t1.pk, t1.c1
FROM t1
UNION ALL
SELECT t2.pk, t2.c1
FROM t2

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

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中插入數據:

INSERT INTO t1(title)
VALUES('row 1'),('row 2'),('row 3');

再來在t2中插入數據:

INSERT INTO t2(title)
VALUES('row 1'),('row 2'),('row 3');

好,咱們接下來就是要使用派生表的方式來對比數據了哦:

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;

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

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

好啦,這次小技巧就到這里了哦。

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數大匯總》、《MySQL日志操作技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》及《MySQL數據庫鎖相關技巧匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

您可能感興趣的文章:
  • MySQL兩種表存儲結構MyISAM和InnoDB的性能比較測試
  • mysql不同數據庫不同數據表導入數據
  • mysql 數據表中查找重復記錄
  • MySQL刪除表數據的方法
  • MySQL實現(xiàn)快速刪除所有表而不刪除數據庫的方法
  • mysql查詢表里的重復數據方法
  • PHP獲取mysql數據表的字段名稱和詳細信息的方法
  • MySQL數據表字段內容的批量修改、清空、復制等更新命令
  • MySQL快速復制數據庫數據表的方法
  • MySQL使用select語句查詢指定表中指定列(字段)的數據
  • MYSQL數據庫中的現(xiàn)有表增加新字段(列)
  • MySQL中查詢所有數據庫占用磁盤空間大小和單個庫中所有表的大小的sql語句

標簽:陽江 鞍山 赤峰 河北 來賓 果洛 煙臺 黃石

巨人網絡通訊聲明:本文標題《mysql實用技巧之比較兩個表是否有不同數據的方法分析》,本文關鍵詞  mysql,實用技巧,之,比較,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mysql實用技巧之比較兩個表是否有不同數據的方法分析》相關的同類信息!
  • 本頁收集關于mysql實用技巧之比較兩個表是否有不同數據的方法分析的相關信息資訊供網民參考!
  • 推薦文章
    东丽区| 无棣县| 西贡区| 江阴市| 阜南县| 彭山县| 永寿县| 民丰县| 临洮县| 广饶县| 靖州| 东莞市| 绍兴县| 榆社县| 蓬安县| 承德县| 东阿县| 大厂| 原平市| 老河口市| 鄂尔多斯市| 甘孜| 丰宁| 青冈县| 桓台县| 肇庆市| 漯河市| 荥经县| 靖州| 金昌市| 砚山县| 牟定县| 通许县| 梅河口市| 龙岩市| 长乐市| 昌宁县| 岢岚县| 泌阳县| 会东县| 历史|