濮阳杆衣贸易有限公司

主頁 > 知識庫 > mysql實(shí)用技巧之比較兩個(gè)表是否有不同數(shù)據(jù)的方法分析

mysql實(shí)用技巧之比較兩個(gè)表是否有不同數(shù)據(jù)的方法分析

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

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

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

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

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

如果真的這樣的話,那你可就真的是啊,too young too simple了。這次呢,咱們來介紹一個(gè)比較簡單的數(shù)據(jù)對比方案,那就是使用union all關(guān)聯(lián)兩張表,完事使用臨時(shí)表或者說派生表的方式來進(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)然是沒有任何返回?cái)?shù)據(jù)的,因?yàn)樗鼈兪菦]有什么差別的。不著急哈,咱們再來在t2表中插入一行數(shù)據(jù):

INSERT INTO t2(title,note)
VALUES('new row 4','new');

完事我們再次比較兩個(gè)表中的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ù)庫計(jì)有所幫助。

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

標(biāo)簽:陽江 鞍山 赤峰 河北 來賓 果洛 煙臺 黃石

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mysql實(shí)用技巧之比較兩個(gè)表是否有不同數(shù)據(jù)的方法分析》,本文關(guān)鍵詞  mysql,實(shí)用技巧,之,比較,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mysql實(shí)用技巧之比較兩個(gè)表是否有不同數(shù)據(jù)的方法分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于mysql實(shí)用技巧之比較兩個(gè)表是否有不同數(shù)據(jù)的方法分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    门头沟区| 偃师市| 平武县| 胶南市| 溧水县| 密山市| 敦化市| 饶阳县| 灵丘县| 津南区| 五华县| 如皋市| 儋州市| 牙克石市| 黄大仙区| 锦屏县| 昌吉市| 多伦县| 东辽县| 黄石市| 楚雄市| 峨边| 扶余县| 湘潭市| 神农架林区| 青浦区| 大关县| 绥德县| 志丹县| 平罗县| 塘沽区| 玛纳斯县| 宜兰县| 屯昌县| 万全县| 潜山县| 兴海县| 洛浦县| 永吉县| 辽阳市| 余干县|