MySql でデータの重複挿入を回避する 3 つの方法

MySql でデータの重複挿入を回避する 3 つの方法

序文

MySql で主キーの競合または一意キーの競合が発生した場合、挿入方法に応じてエラーを回避するための挿入方法が一般的に 3 つあります。

  1. 無視を挿入します。
  2. 置き換える
  3. 重複キーの更新時に挿入

挿入無視

insert ignore は、データベースにすでに存在するデータを無視します。主キーまたは一意のインデックスに基づいてデータベースにデータがない場合、新しいデータを挿入します。データがある場合は、このデータをスキップします。

小型ケース

テーブル構造

ルート:テスト> show create table t3G
************************** 1. 行 ****************************
  表: t3
テーブルの作成: CREATE TABLE `t3` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `c1` int(11) デフォルト NULL,
 `c2` varchar(20) デフォルト NULL,
 `c3` int(11) デフォルト NULL,
 主キー (`id`)、
 ユニークキー `uidx_c1` (`c1`)
) エンジン=InnoDB AUTO_INCREMENT=18 デフォルト文字セット=utf8
セット内の 1 行 (0.00 秒)

ルート:テスト> t3 から * を選択します。
 +----+------+------+------+
 | id | c1 | c2 | c3 |
 +----+------+------+------+
 | 1 | 1 | 1 | 1 |
 | 2 | 2 | 1 |
 | 8 | NULL | NULL | 1 |
 | 14 | 4 | bb | NULL |
 | 17 | 5 | cc | 4 |
 +----+------+------+------+
 セット内の行数は 5 です (0.00 秒)

競合するデータを挿入する

root:test> insert ignore into t3 (c1,c2,c3) values(5,'cc',4),(6,'dd',5); クエリは正常、1行が影響を受け、1つの警告 (0.01秒)
記録: 2 重複: 1 警告: 1

結果を見る

root:test> 警告を表示します。
+---------+------+---------------------------------------+
| レベル | コード | メッセージ |
+---------+------+---------------------------------------+
| 警告 | 1062 | キー 'uidx_c1' のエントリ '5' が重複しています |
+---------+------+---------------------------------------+
セット内の 1 行 (0.00 秒)

ルート:テスト> t3 から * を選択します。
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | 1 | 1 |
| 2 | 2 | 1 |
| 8 | NULL | NULL | 1 |
| 14 | 4 | bb | NULL |
| 17 | 5 | cc | 4 |
| 18 | 6 | dd | 5 |
+----+------+------+------+
セット内の 6 行 (0.00 秒)

置き換える

replace into は最初にデータを挿入しようとし、競合が見つかった場合はそれを削除します。それ以外の場合は何もしないでください。

小型ケース

ルート:テスト> show create table t3G
************************** 1. 行 ****************************
  表: t3
テーブルの作成: CREATE TABLE `t3` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `c1` int(11) デフォルト NULL,
 `c2` varchar(20) デフォルト NULL,
 `c3` int(11) デフォルト NULL,
 主キー (`id`)、
 ユニークキー `uidx_c1` (`c1`)
) エンジン=InnoDB AUTO_INCREMENT=4 デフォルト文字セット=utf8
セット内の 1 行 (0.00 秒)

ルート:テスト> t3 から * を選択します。
+----+------+-------+------+
| id | c1 | c2 | c3 |
+----+------+-------+------+
| 1 | 1 | cc | 4 |
| 2 | 2 | dd | 5 |
| 3 | 3 | いいえ | 3 |
+----+------+-------+------+
セット内の 3 行 (0.00 秒)

競合するデータを挿入する

root:test> t3 (c1,c2,c3) に値を置き換えます(3,'new',8);
クエリは正常、2 行が影響を受けました (0.02 秒)

ルート:テスト> t3 から * を選択します。
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | cc | 4 |
| 2 | 2 | dd | 5 |
| 4 | 3 | 新着 | 8 |
+----+------+------+------+
セット内の 3 行 (0.00 秒)

元のレコードが消えて、新しいレコードが出現したことがわかります。

重複キーの更新時に挿入

insert into 文の最後に insert on duplicate key update を指定した場合、重複した値が出現すると、重複した値が出現した後に更新が行われます。

場合

ルート:テスト> show create table t3G
************************** 1. 行 ****************************
  表: t3
テーブルの作成: CREATE TABLE `t3` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `c1` int(11) デフォルト NULL,
 `c2` varchar(20) デフォルト NULL,
 `c3` int(11) デフォルト NULL,
 主キー (`id`)、
 ユニークキー `uidx_c1` (`c1`)
) エンジン=InnoDB AUTO_INCREMENT=4 デフォルト文字セット=utf8
セット内の 1 行 (0.00 秒)

ルート:テスト> t3 から * を選択します。 
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | 4 |
| 2 | 2 | ユーチュー | 3 |
| 3 | 3 | czx | 5 |
+----+------+------+------+
セット内の 3 行 (0.00 秒)

レコード id=3 の一意のキー (列 c1) と競合するデータを挿入します。

root:test> t3(c1,c2,c3) に値 (3,'new',5) を挿入し、重複キーを更新します。c1=c1+3; 
クエリは正常、2 行が影響を受けました (0.01 秒)

ルート:テスト> t3 から * を選択します。
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | 4 |
| 2 | 2 | ユーチュー | 3 |
| 3 | 6 | czx | 5 |
+----+------+------+------+
セット内の 3 行 (0.00 秒)

id=3 のレコードが変更され、c1=元の c1+3 となり、他の列は変更されていないことがわかります。

上記は、重複データの挿入を回避するための 4 つの MySql メソッドの詳細です。重複データの挿入を回避するための MySQL の詳細については、123WORDPRESS.COM の他の関連記事をご覧ください。

以下もご興味があるかもしれません:
  • MySQL が重複データを挿入するのを防ぐ 3 つの方法
  • MySQLは重複しないデータ挿入を実装するためにUNIQUEを使用する
  • MySQL が重複レコードを挿入するのを防ぐ方法
  • MySql でレコードの重複挿入を回避するいくつかの方法
  • MySQL でデータの重複挿入を回避する 4 つの方法

<<:  Vue でコミュニケーションを実装する 8 つの方法

>>:  Linux のハードリンクとソフトリンクの区別

推薦する

Vue 関数のアンチシェイクとスロットリングの正しい使用方法

序文1. デバウンス: 高頻度イベントがトリガーされた後、関数は n 秒以内に 1 回だけ実行されま...

NFS サーバーの原理と、その構築、構成、展開の手順を簡単に分析します。

目次NFS サービスの概要NFS とは何ですか? NFS マウントの原則NFS サーバーはデータ転送...

Tableとdivの簡単な紹介と使い方

ウェブフロントエンド1学生証名前性別年01張三男20 02李思女性21総人数60フォームのコンポーネ...

Ubuntu16.04にclionをインストールするプロセス全体と手順の詳細な説明

CLion のプロセス全体を最初から説明します。CLion は、JetBrains がリリースした新...

MySQL におけるユニーク制約と NULL の詳細な説明

序文説明を簡略化するために以前に設定した要件は、他のグループから MQ メッセージを受信し、データベ...

CSS3 での 2D および 3D 変換の実装

CSS3 は、要素の 2D 平面変換と視覚的な 3D 空間変換を実装します。2D 変換はより頻繁に使...

タブ切り替え効果を実現するJavaScript

この記事では、タブ切り替え効果を実現するためのJavaScriptの具体的なコードを参考までに紹介し...

Vueはユーザーログインとトークン検証を実装します

フロントエンドとバックエンドを完全に分離する場合、Vue プロジェクトでトークン検証を実装する一般的...

レスポンシブデザインについての簡単な説明

1. レスポンシブ デザインとは何ですか?レスポンシブデザインとは、ウェブサイトの開発プロセス中に、...

Matlab による JavaScript プログラミング、重心アルゴリズムによる位置決め学習

目次Matlab セントロイドアルゴリズムMatlab はクローズドな商用ソフトウェアであり、米国政...

MySQL データベースのステートメント ワイルドカード ファジー クエリの概要

MySQL エラー: パラメータ インデックスが範囲外です (1 > パラメータ数、つまり 0...

初心者のためのWebページ作成: HTMLのハイパーリンクAタグの使い方を学ぶ

ハイパーリンク a タグはリンク ポイントを表し、英語の単語「anchor」の略語です。その機能は、...

Dockerイメージのローカル移行の実装

最近 Docker を勉強しているのですが、よく問題に遭遇します。Docker イメージをダウンロー...

JavaScript の Set データ構造の詳細な説明

目次1. セットとは何か2. セットコンストラクタ2.1) 配列2.2) 文字列2.3) 議論2.4...

初心者向けMySQLシリーズチュートリアル

目次1. 基本概念と基本コマンド1) 基本的な概念2) 基本コマンド2. SQL文の記述順序と実行順...