序文 MySql で主キーの競合または一意キーの競合が発生した場合、挿入方法に応じてエラーを回避するための挿入方法が一般的に 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 の他の関連記事をご覧ください。 以下もご興味があるかもしれません:
|
<<: Vue でコミュニケーションを実装する 8 つの方法
序文1. デバウンス: 高頻度イベントがトリガーされた後、関数は n 秒以内に 1 回だけ実行されま...
目次NFS サービスの概要NFS とは何ですか? NFS マウントの原則NFS サーバーはデータ転送...
ウェブフロントエンド1学生証名前性別年01張三男20 02李思女性21総人数60フォームのコンポーネ...
CLion のプロセス全体を最初から説明します。CLion は、JetBrains がリリースした新...
序文説明を簡略化するために以前に設定した要件は、他のグループから MQ メッセージを受信し、データベ...
CSS3 は、要素の 2D 平面変換と視覚的な 3D 空間変換を実装します。2D 変換はより頻繁に使...
この記事では、タブ切り替え効果を実現するためのJavaScriptの具体的なコードを参考までに紹介し...
フロントエンドとバックエンドを完全に分離する場合、Vue プロジェクトでトークン検証を実装する一般的...
1. レスポンシブ デザインとは何ですか?レスポンシブデザインとは、ウェブサイトの開発プロセス中に、...
目次Matlab セントロイドアルゴリズムMatlab はクローズドな商用ソフトウェアであり、米国政...
MySQL エラー: パラメータ インデックスが範囲外です (1 > パラメータ数、つまり 0...
ハイパーリンク a タグはリンク ポイントを表し、英語の単語「anchor」の略語です。その機能は、...
最近 Docker を勉強しているのですが、よく問題に遭遇します。Docker イメージをダウンロー...
目次1. セットとは何か2. セットコンストラクタ2.1) 配列2.2) 文字列2.3) 議論2.4...
目次1. 基本概念と基本コマンド1) 基本的な概念2) 基本コマンド2. SQL文の記述順序と実行順...