この記事では、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データベース設計に役立つことを願っています。 以下もご興味があるかもしれません:
|
<<: VScode リモート SSH リモート編集とデバッグコード
>>: すべてまたは逆の選択機能を実現するJavaScript
1. DockerでのPostgresデータベースのバックアップ注文: docker exec it...
目次方法1 1. 構成とインストールの手順:方法2方法3要約する方法1 1. 構成とインストールの手...
まずMySQLの公式ドキュメントを見てみましょう: 5.7 {データベース | スキーマ} を作成 ...
1. 中国語入力方法を設定する 2. ダブルスペルモードを設定する 3. 注意事項20.04 で S...
数日前、同僚からMySQLのインデックスについて質問を受けました。大体わかっているのですが、まだ練習...
この記事は、CentOS 7の詳細なインストールチュートリアルを参考のために記録します。具体的な内容...
目次DockerバージョンCentOS に Docker エンジンをインストールするシステム要件古い...
SQL はメイントランクです。なぜ私はこのように理解するのでしょうか。技術的な観点からリレーショナル...
以下にリストされているすべてのブログはオリジナルであり、独自にデザインされています。これらは、他者が...
おそらく、この問題にまだ遭遇していない人もいるでしょうから、まずは適応高さとは何かを説明しましょう。...
Shell で受信パラメータを受信する方法は 2 つあることがわかっています。 1 つはスクリプト...
序文innodb_data_file_path は、innodb テーブルスペース ファイルを指定す...
一般的に言えば、HTML ドキュメント内で極端に大きな <ol> リストに遭遇する可能性...
ページコンテンツ全体を中央に配置する方法と、コンテンツに合わせて高さを自動的に拡大縮小する方法。これ...
この記事では、参考までにMySQLのインストールと設定のチュートリアルを紹介します。具体的な内容は次...