MySQLで論理SQLを置き換える際の落とし穴を回避する方法の詳細な説明

MySQLで論理SQLを置き換える際の落とし穴を回避する方法の詳細な説明

重複キーの置換と挿入の違い

置換の使用法

競合がない場合、挿入と同等となり、他の列のデフォルト値が使用されます。キー競合がある場合、自動インクリメント列が更新され、競合している列が置き換えられ、他の列のデフォルト値が使用されます。
Com_replaceは1を追加します
Innodb_rows_updatedは1を追加します

重複キーでの Insert into … の使用法

競合がない場合は挿入と同等です。他の列のデフォルト値がキーと競合する場合は、該当するフィールドの値のみ更新されます。
Com_insertは1を追加します
Innodb_rows_insertedが1増加する

実験的デモンストレーション

テーブル構造

テーブルhelei1を作成します(
id int(10) 符号なし NOT NULL AUTO_INCREMENT,
名前 varchar(20) NOT NULL DEFAULT ''
年齢 tinyint(3) unsigned NOT NULL デフォルト 0,
主キー(id)、
ユニークキー uk_name (名前)
)
エンジン=innodb AUTO_INCREMENT=1 
デフォルト文字セット=utf8;

テーブルデータ

[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 1 | 何磊 | 26 |
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
+----+-----------+-----+
セット内の 3 行 (0.00 秒)

使用法に置き換える

[email protected] (helei)> replace into helei1 (name) values('贺磊');
クエリは正常、2 行が影響を受けました (0.00 秒)
[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
| 4 | 何磊 | 0 |
+----+-----------+-----+
セット内の 3 行 (0.00 秒)
[email protected] (helei)> helei1 (name) の値('爱璇') に置き換えます。
クエリは正常、1 行が影響を受けました (0.00 秒)
[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
| 4 | 何磊 | 0 |
| 5 | アイシュアン | 0 |
+----+-----------+-----+
セット内の 4 行 (0.00 秒)

置換の使用法

キーの競合がない場合、replace into は insert と同等となり、他の列のデフォルト値が使用されます。

キーの競合が発生すると、自動増分列が更新されて競合する列が置き換えられ、残りの列はデフォルト値に設定されます。

重複キーに…を挿入:

[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
| 4 | 何磊 | 0 |
| 5 | アイシュアン | 0 |
+----+-----------+-----+
セット内の 4 行 (0.00 秒)
[email protected] (helei)> insert into helei1 (name,age) values('贺磊',0) on duplicate key update age=100;
クエリは正常、2 行が影響を受けました (0.00 秒)
[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
| 4 | 何磊 | 100 |
| 5 | アイシュアン | 0 |
+----+-----------+-----+
セット内の 4 行 (0.00 秒)
[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
| 4 | 何磊 | 100 |
| 5 | アイシュアン | 0 |
+----+-----------+-----+
セット内の 4 行 (0.00 秒)
[email protected] (helei)> insert into helei1 (name) values('爱璇') on duplicate key update age=120;
クエリは正常、2 行が影響を受けました (0.01 秒)
[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
| 4 | 何磊 | 100 |
| 5 | 愛軒 | 120 |
+----+-----------+-----+
セット内の 4 行 (0.00 秒)
[email protected] (helei)> 重複キーの helei1 (name) 値に ('存在しません') を挿入し、age=80 を更新します。
クエリは正常、1 行が影響を受けました (0.00 秒)
[email protected] (helei)> helei1 から * を選択します。
+----+-----------+-----+
| ID | 名前 | 年齢 |
+----+-----------+-----+
| 2 | シャオミン | 28 |
| 3 | シャオホン | 26 |
| 4 | 何磊 | 100 |
| 5 | 愛軒 | 120 |
| 8 | 存在しない | 0 |
+----+-----------+-----+
セット内の行数は 5 です (0.00 秒)

要約する

replace into の使用は、最初に削除操作を実行し、競合するキーが見つかった場合は挿入操作を実行することと同じです。指定されていない列にはデフォルト値が使用されます。これにより、自動増分主キーが変更されます。テーブルに外部キーがある場合、またはビジネス ロジックが主キーに依存している場合は、例外が発生します。したがって、重複キーには Insert into … を使用することをお勧めします。執筆時間が急ぎだったため、記事には多少の誤りや不正確な点が避けられません。不適切な点がありましたら、ご指摘、ご訂正をお願いいたします。

さて、以上がこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただきありがとうございます。

以下もご興味があるかもしれません:
  • MySQLの論理アーキテクチャに関する深い理解
  • MYSQLストアドプロシージャ、つまり一般的な論理知識のポイントの要約
  • MySQL 上級学習ノート (パート 3): MySQL 論理アーキテクチャの紹介、MySQL ストレージ エンジンの詳細な説明
  • MySQLの実行原理、論理階層化、データベース処理エンジンの変更について詳しく説明します
  • Mysql論理アーキテクチャの詳細な説明
  • PHPを使用してMySqlデータベースにアクセスする論理操作と追加、削除、変更、チェックの例
  • MySql ストアド プロシージャの論理的判断と条件制御
  • MySQLはテーブルデータを復元するためにfrmファイルとibdファイルを使用します
  • MySQLはデータ復旧を実装するためにbinlogログを使用する
  • 時点に基づくMySQLクイックリカバリソリューション
  • MySQL5.7 mysqldump バックアップとリカバリの実装
  • MySQL 論理バックアップとリカバリ テストの概要

<<:  Nginx で https をアップグレードする方法

>>:  JavaScript における正規表現の実際的な応用の詳細な説明

推薦する

vue ルーティング ビュー router-view のネストされたジャンプの実装

目次1. app.vueページを修正する2. ログインページを作成する (/views/login/...

MySQL における悲観的ロックと楽観的ロック

リレーショナル データベースでは、悲観的ロックと楽観的ロックがリソース同時実行シナリオのソリューショ...

MySQLストレージエンジンについて学びましょう

目次序文1. MySQL メインストレージエンジン: 2. さまざまなストレージエンジンがテーブルを...

RoughViz を使用して Vue.js でスケッチされたチャートを視覚化する方法

導入チャートは、データ セットを読みやすくし、その各部分を区別しやすくするために使用されるデータのグ...

Nginx をインストールして複数のドメイン名を設定する方法

Nginx のインストールCentOS 6.x yum にはデフォルトで nginx ソフトウェア ...

MySQL のデータ統計に関するヒント

よく使用されるデータベースである MySQL では、多くの操作が必要です。デジタル操作には非常に便利...

CSS で画像アダプティブ コンテナを実装するいくつかの方法 (要約)

多くの場合、画像をコンテナのサイズに合わせて調整する必要があります。 1. imgタグ方式幅と高さを...

Ubuntuがネットワークに接続できない場合の解決策

仮想マシン内の Ubuntu がネットワークに接続できない場合の効果的な解決策: 1. Ubuntu...

React は入力値を取得し、2 つのメソッドの例を送信します

方法1: DOMが提供するイベントオブジェクトのターゲットイベント属性を使用して値を取得し、送信する...

MongoDB の起動エラーを解決します: 共有ライブラリのロード中にエラーが発生しました: libstdc++.so.6: 共有オブジェクト ファイルを開けません:

MongoDB を起動すると、プロンプトは次のようになります。共有ライブラリのロード中にエラーが発...

Vueプロジェクトでスケルトンスクリーンを使用する方法

現在、アプリケーション開発は基本的にフロントエンドとバックエンドに分離されています。主流のフロントエ...

MySQL のインデックスと制約の例文

外部キーテーブルの主キーがどのテーブルの外部キーであるかを照会する 選択 テーブル名、 列名、 制約...

マウスを動かしたときにセカンダリメニューバーを実装するために HTML+CSS を使用する例

この記事では、マウスを動かしたときにセカンダリ メニュー バーを実装するために HTML+CSS を...

MySQLからMariaDBへのスムーズな移行のための詳細な手順

1. MariaDB と MySQL の紹介1. MariaDB の紹介MariaDB は、MySQ...

MySQLの日付と時刻の間隔計算の分析例

この記事では、例を使用して、MySQL の日付と時刻の間隔計算について説明します。ご参考までに、詳細...