MySQL の replace と replace into の詳細な例 into_Mysql

MySQL の replace と replace into の詳細な例 into_Mysql

MySQL の replace と replace into はどちらも頻繁に使用される関数です。replace は、最初に削除してから挿入するのではなく、実際に更新操作を実行します。また、replace into は実際には insert into と非常によく似ていますが、replace into の場合、テーブル内の古いレコードが PRIMARY KEY または UNIQUE インデックスの新しいレコードと同じ値を持つ場合、新しいレコードが挿入される前に古いレコードが削除されます。

Replace は、文字列を処理するために MySQL でよく使用される関数であり、文字列内の内容を置き換えることができます。また、trim と呼ばれる同様の文字列処理操作もありますが、ここでは詳しく説明しません。

replace into の主な機能は、挿入操作に似ています。主な違いは、replace は主キーまたは一意のインデックスに基づいてデータが存在するかどうかを確認し、存在する場合は更新前に削除することです。

例:

#テーブル構造:

テーブル `t_test` を作成します (

`id` int(11) 符号なし NOT NULL AUTO_INCREMENT,

`name` varchar(1) NOT NULL DEFAULT ''

主キー (`id`)、

BTREE を使用したユニーク キー `idx_name` (`name`)

) エンジン=InnoDB デフォルト文字セット=utf8mb4

最初のレコードを挿入する

t_test (`name`) に値 ('a') を挿入します

#または

t_test (`name`) VALUES ('a') に置き換えます

上記の方法を使用して 2 つのレコードを挿入すると、挿入によってエラーが表示されます: 1062 - キー 'idx_name' のエントリ 'a' が重複しています。時間: 0.001000 秒。 replace into を使用すると、 id が 1 増加する点を除いて、通常どおり実行されます。

ps: replace into のキーワード into は省略できます。見た目は同じですが、使い方が少し異なります。

1. replace(オブジェクト,検索,置換)

オブジェクト内の検索のすべての出現を置換で置き換えます

... から replace('www.jb51.net','w','n') を選択 ---> nnn.jb51.net

例: テーブルの名前フィールドの詳細を説明に置き換える

テーブルを更新します。名前をreplace(name,'detail','description')に設定します。

2. を置き換える

同等: if not exists (select 1 from t where id = 1) insert into t(id, update_time) values(1, getdate()) else update t set update_time = getdate() where id = 1;

REPLACE は INSERT とほぼ同じように動作します。テーブル内の古いレコードが PRIMARY KEY または UNIQUE インデックスの新しいレコードと同じ値を持つ場合、新しいレコードが挿入される前に古いレコードが削除されます。

テーブルに PRIMARY KEY または UNIQUE インデックスがない場合は、REPLACE ステートメントを使用しても意味がないことに注意してください。このステートメントは、新しい行が他の行と重複しているかどうかを判断するためにインデックスが使用されないために、INSERT と同一になります。

すべての列の値は、REPLACE INTO ステートメントで指定された値から取得されます。欠落している列は、INSERT INTO の場合と同様に、デフォルト値に設定されます。現在の行の値を参照することも、新しい行の値を使用することもできません。 「SET col_name = col_name + 1」のような代入を使用すると、右側の列名への参照は DEFAULT(col_name) として扱われます。したがって、この割り当ては SET col_name = DEFAULT(col_name) + 1 と同等です。

REPLACE INTO を使用するには、テーブルに対する INSERT および DELETE 権限が必要です。

REPLACE ステートメントは、影響を受ける行の数を示す数値を返します。この数値は、削除された行と挿入された行の合計数です。単一行の REPLACE でこの数値が 1 の場合、行が挿入され、行は削除されません。この数値が 1 より大きい場合、新しい行が挿入される前に 1 つ以上の古い行が削除されました。テーブルに複数の一意のインデックスが含まれており、新しい行が異なる一意のインデックスの異なる古い行の値を複製する場合、1 つの行で複数の古い行を置き換えることが可能になります。

影響を受ける行数により、REPLACE によって 1 行のみが追加されたのか、それとも REPLACE によって他の行も置き換えられたのかを簡単に判断できます。数が 1 (追加) 以上 (置き換え) かどうかを確認します。

現在、テーブルを変更してサブクエリで同じテーブルから選択することはできません。

使用されるアルゴリズムの詳細な説明は次のとおりです (このアルゴリズムは LOAD DATA ... REPLACE にも使用されます)。

1. テーブルに新しい行を挿入してみる

2. 主キーまたは一意キーの重複キー エラーが原因で挿入が失敗した場合:

a. テーブルから重複するキー値を含む競合行を削除する

b. テーブルに新しい行を再度挿入してみます

3 つの形式:

  1. tbl_name(col_name, ...) の値に置き換えます(...)
  2. tbl_name(col_name, ...) に置き換えて、... を選択します。
  3. tbl_name に置き換え、col_name=value を設定します...

追伸:

MySQL にデータを挿入するためによく使用される 3 つのステートメント:

insert into はデータを挿入することを意味します。データベースは主キーをチェックし、重複がある場合はエラーを報告します。

replace into は、データを挿入して置き換えることを意味します。テーブルには、PrimaryKey または一意のインデックスが必要です。データベースにすでにデータが存在する場合は、新しいデータに置き換えられます。データがない場合、効果は insert into と同じです。

insert ignore は、同じレコードがすでに存在する場合、現在の新しいデータが無視されることを意味します。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。これについてもっと知りたい場合は、次のリンクをご覧ください。

これで、MySQL into_Mysql での replace および replace into の使用に関する詳細なケース分析に関するこの記事は終了です。MySQL into_Mysql での replace および replace into の使用に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL での重複キー更新時の replace into と insert into の使用法と相違点の分析
  • MySQL での置換例の詳細な説明
  • MySQL の replace into ステートメントの簡単な分析 (パート 2)
  • MySQLのreplace into文の簡単な分析(I)
  • MySQL の replace into ステートメントの使用方法の詳細な説明
  • MySQLの置換の使用法の簡単な分析

<<:  燃える炎効果の英語フォント16種類をシェアする

>>:  Jenkins Docker 静的エージェント ノードのビルド プロセス

推薦する

Nexus をベースに Alibaba Cloud プロキシ ウェアハウスを構成するプロセスの分析

Nexus のデフォルトのリモートリポジトリは https://repo1.maven.org/ma...

CSS で雨滴アニメーション効果を実装するサンプルコード

ガラス窓今日実現するのは雨滴効果です。ただし、雨滴効果を実現する前に、まずは曇りガラス効果を作成しま...

js の Array.forEach でループを終了する方法の例

目次forEach() メソッドjs の Array.forEach のループから抜け出す方法解決:...

Mysql ALTER TABLE はフィールドを追加するときにテーブルをロックしますか?

目次MySQL 5.6以前MySQL 5.6以降要約する知らせMySQL 5.6以前更新手順元のテー...

要素テーブルの多層ネスト表示の実践

複数の注文を含むリストが必要です。各注文は一意にすることも、複数の注文を結合することもできます。各注...

Tomcatのクラスロードメカニズムのプロセスとソースコード分析

目次序文1. Tomcat クラスローダー構造図: 2. Tomcat のクラスロードプロセスの説明...

Navicat による MySQL パーティショニングの実践

MySQLのパーティショニングは、非常に大きなテーブルを管理するのに役立ちます。MySQLのパーティ...

MySQL 単一テーブルクエリの例の詳細な説明

1. データを準備するこのテーブルでは次の操作が実行されます 学生テーブルを作成 ( id int ...

CSSスタイルの記述順序と命名規則と注意事項

書き順の重要性ブラウザのリフローを減らし、ブラウザのDOMレンダリングパフォーマンスを向上させる①:...

初心者がソースコードからMySQLのデッドロック問題を理解する

夜遅くまで何度も困難なシングルステップデバッグを行った後、ようやく理想的なブレークポイントを見つけま...

nginx で HSTS を有効にしてブラウザを HTTPS アクセスにリダイレクトする方法の詳細な説明

前回の記事では、https を使用したローカルノードサービスアクセスを実装しました。前回の記事の効果...

JavaScript WebAPI、DOM、イベント、操作要素例の詳しい説明

目次ウェブAPI DOM DOMツリーDOM要素取得方法ドキュメントオブジェクトのプロパティイベント...

NodeとPythonの双方向通信実装コード

目次プロセスコミュニケーションプロセス間の双方向通信問題要約するサードパーティのデータ サプライヤー...

CSS スタイルを HTML 外部スタイルシートにインポートする方法

リンクインスタイルとは、すべてのスタイルを 1 つ以上の外部スタイルシート ファイルに配置することで...

Vue の親子コンポーネントの値転送と一方向データフローの問題の詳細な説明

目次序文1. 親コンポーネントが子コンポーネントに値を渡す2. サブコンポーネントのprops型制約...