mysql replace into の使用法の詳細な説明

mysql replace into の使用法の詳細な説明

replace ステートメントは、一般的に insert ステートメントに似ています。ただし、テーブルに主キーまたは一意のインデックスがある場合、挿入されたデータが元の主キーと同じか一意であれば、元のデータは削除され、新しいデータが追加されます。そのため、replace ステートメントを実行することは、delete ステートメントと insert ステートメントを実行することと同じになることがあります。早速例を見てみましょう。

id、title、uid の 3 つのフィールドを持つテスト テーブルを作成します。id は自動インクリメントの主キーで、uid は一意のインデックスです。

テーブル「test」を作成します(
 `Id` int(11) NOT NULL AUTO_INCREMENT,
 `title` varchar(25) デフォルト NULL コメント 'タイトル',
 `uid` int(11) デフォルト NULL コメント 'uid',
 主キー (`Id`)、
 ユニークキー `uid` (`uid`)
)ENGINE=InnoDB デフォルト文字セット=utf8mb4;

test(title,uid) に VALUES ('Hello','1') を挿入します。
test(title,uid) に VALUES ('National Day','2') を挿入します。

結果は次のとおりです。

replace into を使用してデータを挿入する場合:

test(title,uid) VALUES ('今回は8日間休みです','3') に置き換えます。

uidが存在する場合は、replace intoステートメントを使用します

REPLACE INTO test(title,uid) VALUES ('これはUid=1の最初のデータです','1');

MySQL がデータの競合 (つまり、uid の重複) に遭遇したときに、実際に古いレコードを削除して新しいレコードを書き込むとは予想していませんでした。上記の例から、ブロガーは次のことがわかると思います。

replace into は insert と似ていますが、replace into は最初にテーブルにデータを挿入しようとする点が異なります。

1. このデータ行がテーブル内に既に存在することが判明した場合 (主キーまたは一意のインデックスによって決定)、まずこのデータ行を削除してから、新しいデータを挿入します。 2. それ以外の場合は、新しいデータを直接挿入します。

データが挿入されるテーブルには、主キーまたは一意のインデックスが必要であることに注意してください。そうでない場合、replace into はデータを直接挿入し、テーブルに重複したデータが生成されます。

MySQL の replace into には 3 つの形式があります。

1. tbl_name(col_name, ...) の値に置き換えます(...)

2. tbl_name(col_name, ...) に置き換えて、... を選択します。

3. tbl_name に col_name=value を設定し、... を置き換えます。

最初の形式は insert into の使用法に似ています。

replace select の 2 つ目の使用法も insert select に似ています。この使用法では、列名が一致している必要はありません。実際、MYSQL は select によって返される列名を気にしません。必要なのは列の位置です。たとえば、replace into tb1( name, title, mood) select rname, rtitle, rmood from tb2; この例では、replace into を使用して、tb2 のすべてのデータを tb1 にインポートします。

3 番目の置換セットの使用方法は、更新セットの使用方法と似ています。「SET col_name = col_name + 1」などの割り当てを使用すると、右側の列名への参照は DEFAULT(col_name) として扱われます。したがって、この割り当ては SET col_name = DEFAULT(col_name) + 1 と同等です。

最初の 2 つの形式の方が頻繁に使用されます。キーワード「into」は省略できますが、意味がより直感的になるように「into」を追加した方がよいでしょう。さらに、値が指定されていない列については、MySQL によって自動的にデフォルト値が割り当てられます。

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

<<:  1 つの記事で JSON (JavaScript Object Notation) を理解する

>>:  Dockerコンテナイメージからコードを復元する手順

推薦する

CSSはリモコンのボタンを模倣する

注: このデモはミニプログラム環境でテストされており、他の h5 および pc Web ページにも適...

MySQLは間違ったパスワードを入力する試行回数を制御します

1. 本番環境でMySQLのデッドロックを監視し、デッドロックの可能性を減らす方法まず、デッドロック...

Javascript の奇妙な点をご存知ですか?

私たちのベテランの先人たちは、数え切れないほどのコードを書き、数え切れないほどの落とし穴に陥ってきま...

MySql バッチ挿入の最適化 SQL 実行効率の例の詳細な説明

MySql バッチ挿入の最適化 SQL 実行効率の例の詳細な説明itemcontractprice ...

Vue テンプレート構成と Webstorm コード形式仕様設定

目次1. コンパイラコードフォーマット仕様設定2. Vueテンプレートの設定1. コンパイラコードフ...

jsはシンプルな英語-中国語辞書を実装します

この記事では、参考までに、簡単な英中辞典を実装するためのjsの具体的なコードを紹介します。具体的な内...

Vue2 と Vue3 でウォッチ リスナーを使用する方法

watch : データの変更を監視する(特定の値の変更イベント) vue2.x データ(){ 戻る ...

Windows で MySQL 5.6 を 5.7 にアップグレードする方法

前面に書かれたMySQL をアップグレードする方法には、インプレース アップグレードと論理アップグレ...

mysql ビュー関数の分析と使用例

この記事では、例を使用して MySQL ビューの機能と使用方法を説明します。ご参考までに、詳細は以下...

Vueカスタムディレクティブの詳細

目次1. 背景2. ローカルカスタム指示3. グローバルカスタム指示4.1 カスタムコマンドフック関...

さまざまなターミナルで Mac が SSH 経由でリモート サーバーに接続する方法の説明

Macはシェル(ターミナル)SSHを使用してリモートサーバーに接続します前提条件: 接続する必要があ...

Vue の 4 つのカスタム命令の説明と使用例

4つの実用的なVueカスタム指示1. Vドラッグ要件: マウスドラッグ要素アイデア:要素のオフセット...

Nginx が Apache より優れている理由

Nginx は、わずか数年で Web サーバー市場の大部分を占めるようになりました。周知のとおり、N...

シンプルなカレンダー効果を実現する JavaScript コード

この記事では、シンプルなカレンダー効果を実現するためのJavaScriptの具体的なコードを参考まで...

Linux でリモート サーバー ファイルの状態を表示する方法

以下のように表示されます。 test コマンドはファイルが存在するかどうかを判断します。 ssh u...