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 静的エージェント ノードのビルド プロセス

推薦する

Linuxの読み取りコマンドの使用

1. コマンドの紹介read コマンドは、シェルの組み込みコマンドで、標準入力または -u オプショ...

HTML+CSS+JS でキャンバスがマウスの小さな円に追従する特殊効果のソースコードを実現

効果(ソースコードは最後にあります): 成し遂げる: 1. タグを定義します。 <h1>...

ウェブページ経由で jar パッケージを Nexus にアップロードする方法

Maven を使用してプロジェクトを管理する場合、jar パッケージをプライベート ウェアハウスにア...

Linux で scp コマンドを使用してファイルをリモートでコピーする方法の詳細な説明

序文scp は secure copy の略です。scp は、Linux システムの ssh ログイ...

CSS における px、em、rem、pt の特徴、違い、変換について詳しく説明します。

コンセプト紹介: 1. px (ピクセル):仮想的な長さの単位で、コンピュータ システムのデジタル画...

この記事では、Vueのフロントエンドページングとバックエンドページングを実装する方法を説明します。

目次1: フロントエンドの手書きページング(データ量が少ない場合) 2: バックエンドのページング、...

MySQL 5.6.23 のインストールと設定環境変数のチュートリアル

この記事では、MySQL 5.6.23のインストールと設定のチュートリアルを参考までに紹介します。具...

Linux でログインタイムアウト後に非アクティブなユーザーを自動的にログアウトする

方法1: .bashrcまたは.bash_profileファイルを変更するこれは、ホーム ディレクト...

MySQLのROUND関数の丸め演算における落とし穴の分析

この記事では、MySQL の ROUND 関数を使用した丸め操作の落とし穴を例を使って説明します。ご...

Mybatis+mysqlはストアドプロシージャを使用してシリアル番号実装コードを生成します。

同時操作によるデータの重複を避けるために、データベースを操作するときにストアドプロシージャを使用して...

DockerコンテナでのMySQLデータのインポート/エクスポートの詳細な説明

序文MySQL データのインポートとエクスポートは mysqldump コマンドで解決できることは誰...

Mysql Explainコマンドの使用と分析

mysql explain コマンドは、MySQL がインデックスを使用して選択ステートメントを処理...

CentOS7 上で KVM 仮想化プラットフォームを構築する (3 つの方法)

KVM はカーネルベースの仮想マシンの略で、Linux をハイパーバイザーに変換する Linux ...

docker compose helloworld を使い始めるための詳細なプロセス

前提条件Compose は、Docker コンテナをオーケストレーションするためのツールです。Doc...

ページ内にマーキーとフラッシュが共存する場合の競合解決

競合の主な症状は、FLASH ボタンがジャンプし続け、不安定になり、Web ページの外観と通常のアク...