MySQL実践スキル: 2つのテーブルに異なるデータがあるかどうかを比較する方法の分析

MySQL実践スキル: 2つのテーブルに異なるデータがあるかどうかを比較する方法の分析

この記事では、MySQL が 2 つのテーブルを比較して、異なるデータがあるかどうかを確認する方法を例を使って説明します。ご参考までに、詳細は以下の通りです。

データ移行では、多くの場合、2 つのテーブルを比較して、一方のテーブルに、もう一方のテーブルに対応するレコードがないレコードを識別する必要があります。

たとえば、古いデータベースとは異なるスキーマを持つ新しいデータベースがあるとします。私たちの仕事は、古いデータベースから新しいデータベースにすべてのデータを移行し、データが正しく移行されたことを確認することです。データをチェックするには、新しいデータベースと古いデータベースの 2 つのテーブルを比較し、一致しないレコードを特定する必要があります。

t1 と t2 という 2 つのテーブルがあるとします。次の手順で 2 つのテーブルを比較し、一致しないレコードを特定します。一般的な考え方は、最初に t1 をチェックし、次にデータ結果セットをループして、他のテーブルを 1 つずつクエリすることです。データが見つかった場合、そのデータは正しいです。見つからない場合、データが欠落しています。

もしこれが本当なら、あなたは本当に若すぎて単純すぎるのです。今回は、union all を使用して 2 つのテーブルを結合し、一時テーブルまたは派生テーブルを使用してデータを比較するという、より簡単なデータ比較ソリューションを紹介します。 union all の SQL の例を見てみましょう。

t1.pk、t1.c1を選択します。
t1から
ユニオンオール
t2.pk、t2.c1を選択します。
t2から

その後、2 つのテーブルを作成し、データを挿入します。その後、テストを行うことができます。まずはテーブルの作成方法を見てみましょう。

テーブルt1を作成します(
 id int auto_increment 主キー、
  タイトルvarchar(255) 
);
テーブルt2を作成します(
 id int auto_increment 主キー、
  タイトルvarchar(255)、
  メモvarchar(255)
);

その後、t1 にデータを挿入します。

t1(タイトル)に挿入
VALUES('行1'),('行2'),('行3');

t2 にデータを挿入してみましょう:

t2(タイトル)に挿入
VALUES('行1'),('行2'),('行3');

では、派生テーブルを使用してデータを比較してみましょう。

SELECT id,タイトル
から (
  t1からid、titleを選択
  ユニオンオール
  t2からid、titleを選択
) 表
GROUP BY id、タイトル
count(*) = 1 である
ID で並べ替える;

もちろん、それらの間に違いはないので、実行後に返されるデータはありません。心配しないでください。t2 テーブルに別のデータ行を挿入しましょう。

t2(タイトル、メモ)に挿入
VALUES('新しい行4','新しい');

その後、2つのテーブルのタイトル列の値を再度比較します。新しい行は一致しない行なので、それが返されます。結果を見てみましょう。

mysql> SELECT id,title
から (
  t1からid、titleを選択
  ユニオンオール
  t2からid、titleを選択
) 表
GROUP BY id、タイトル
count(*) = 1 である
ID で並べ替える;
+----+-----------+
| ID | タイトル |
+----+-----------+
| 4 | 新しい行 4 |
+----+-----------+
セット内の1行

さて、今回のヒントは以上です。

MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL クエリ スキル」、「MySQL 共通関数の概要」、「MySQL ログ操作スキル」、「MySQL トランザクション操作スキルの概要」、「MySQL ストアド プロシージャ スキル」、および「MySQL データベース ロック関連スキルの概要」

この記事が皆様のMySQLデータベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • MySQL の 2 つのテーブル ストレージ構造 MyISAM と InnoDB のパフォーマンス比較テスト
  • MySQL の異なるデータベースの異なるテーブルからデータをインポートする
  • MySQLテーブル内の重複レコードを見つける
  • MySQLでテーブルデータを削除する方法
  • データベースを削除せずにMySQLのすべてのテーブルを素早く削除する方法
  • MySQLテーブル内の重複データをクエリする方法
  • PHP で MySQL テーブルのフィールド名と詳細情報を取得する方法
  • MySQLデータテーブルフィールドの内容に対するバッチ変更、クリア、コピー、その他の更新コマンド
  • MySQLデータベーステーブルを素早くコピーする方法
  • MySQLは、SELECT文を使用して、指定されたテーブルの指定された列(フィールド)のデータを照会します。
  • MYSQLデータベースの既存のテーブルに新しいフィールド(列)を追加する
  • MySQL で、すべてのデータベースが占有するディスク容量と、単一データベース内のすべてのテーブルのサイズを照会する SQL ステートメント

<<:  VScode リモート SSH リモート編集とデバッグコード

>>:  すべてまたは逆の選択機能を実現するJavaScript

推薦する

node.js チュートリアルの Util モジュールの例の詳細な説明

目次タイプ判定から始める厳格な平等エラーファーストと約束デバッグと出力タイプ判定から始めるJavaS...

MySQL クエリの重複データ (重複データを削除し、ID が最も小さいデータのみを保持します)

開発の背景:最近、私はバッチ データを MySQL データベースにインポートする機能に取り組んでいま...

Vue での keepAlive の使用例の詳細な説明

開発においては、一覧から詳細ページにジャンプし、また詳細ページに戻る際に一覧ページの状態(スクロール...

行の高さと垂直方向の配置に関する包括的な理解

前の単語line-height、font-size、vertical-align は、インライン要素...

Reactにおける不変値の説明

目次不変の値とは何ですか?不変の値を使用するのはなぜですか? Reactのパフォーマンス最適化は不変...

MySQLクエリプランでken_lenの値を計算する方法

key_lenの意味MySQL では、次に示すように、explain を使用して SQL ステートメ...

Vueは動的ルーティングの詳細を実装します

目次1. フロントエンド制御1. router.js ファイル内 (router.js にそれぞれ静...

Reactベースのコンポーネントのカプセル化の実装手順

目次序文antd はどのようにしてコンポーネントをカプセル化するのでしょうか?ディバイダーコンポーネ...

VSCode と SSH を使用したリモート開発

0. リモート開発が必要な理由組み込み Linux を開発する場合、便宜上、通常は Windows ...

CSS グリッドレイアウトで列にアイテムを埋め込む方法

n 個のアイテムがあり、これらのアイテムをグリッド レイアウトの列に並べ替える必要があるとします。列...

CSS3はキングをマッチングさせるときにパーティクルアニメーション効果を実現します

コーディングをしていると、多くのことが同じ結末を迎えることに気づくでしょう。問題を解決する方法は何千...

node-media-serverを使用してシンプルなストリーミングメディアサーバーを構築する

node-media-server を使用するプロセスの一部を記録します。この記事の環境はWindo...

MySQL 8.0 の binlog の詳細な説明

1 はじめにバイナリ ログは、データを持つ、またはデータを変更する可能性がある SQL ステートメン...

Reactは無限ループスクロール情報を実装する

この記事では、無限ループスクロールを実現するためのReactの具体的なコードを参考までに紹介します。...