MySQLで置換関数を実装するためのいくつかの実用的なシナリオ

MySQLで置換関数を実装するためのいくつかの実用的なシナリオ

REPLACE構文

REPLACE(String,from_str,to_str)

つまり、String 内の from_str のすべての出現を to_str に置き換えます。ここで、from_str は正規表現の一致をサポートしていません。

操作例

テストテーブルデータは次のとおりです。

mysql> `LOL` から * を選択します。
+----+----------------+--------------+-------+
| id | ヒーロータイトル | ヒーロー名 | 価格 |
+----+----------------+--------------+-------+
| 1 | ブレードシャドウ | タロン | 6300 |
| 2 | スウィフトスカウト | ティーモ | 6300 |
| 3 | ラディアントレディ AA | ルクス | 1350 |
| 4 | クロックワーク A、召喚 A | オリアナ | 6300 |
| 5 | 至高の拳 | リー・シン | 6300 |
| 6 | 武芸剣士 | 簡単 | 450 |
| 7 | 速攻剣士 | ヤスオ | 6300 |
+----+----------------+--------------+-------+
セット内の行数は 7 です (0.00 秒)

使用シナリオ 1 – (クエリ ステートメント):

要件: 「hero_title」フィールド内のすべての「之」を「 - 」に置き換えて表示します。SQL は次のとおりです。

LOL から、repl_title、hero_name、price として REPLACE(hero_title、'之'、' - ') を選択します。
mysql> SELECT REPLACE(hero_title,'之',' - ') as repl_title,hero_name,price from `LOL`;
+----------------+--------------+-------+
| repl_title | ヒーロー名 | 価格 |
+----------------+--------------+-------+
| ブレード - シャドウ | タロン | 6300 |
| スウィフトスカウト | ティーモ | 6300 |
| ラディアントレディAA | ルクス | 1350 |
| クロックワーク A、ジーニー A | オリアナ | 6300 |
| 至高 - 拳 | リー・シン | 6300 |
| 武芸剣マスター | 簡単 | 450 |
| スイフトブレードマスター | ヤスオ | 6300 |
+----------------+--------------+-------+
セット内の行数は 7 です (0.00 秒)

使用シナリオ 2 – (更新ステートメント):

要件: 「hero_title」フィールドのすべての「A」を削除します。SQL は次のとおりです。

LOL を更新します。 SET hero_title=REPLACE(hero_title,'A','');

mysql> UPDATE `LOL` SET hero_title=REPLACE(hero_title,'A','');
クエリは正常、2 行が影響を受けました (0.05 秒)
一致した行: 7 変更: 2 警告: 0
-- 削除してクエリ:
+----+--------------+--------------+-------+
| id | ヒーロータイトル | ヒーロー名 | 価格 |
+----+--------------+--------------+-------+
| 1 | ブレードシャドウ | タロン | 6300 |
| 2 | スウィフトスカウト | ティーモ | 6300 |
| 3 | レディアント | ルクス | 1350 |
| 4 | クロックワーク ジーニー | オリアナ | 6300 |
| 5 | 至高の拳 | リー・シン | 6300 |
| 6 | 武芸剣士 | 簡単 | 450 |
| 7 | 速攻剣士 | ヤスオ | 6300 |
+----+--------------+--------------+-------+
セット内の行数は 7 です (0.00 秒)

使用シナリオ 3 – (置換または挿入: REPLACE INTO)

新しいレコードを挿入したい場合 (INSERT)、レコードがすでに存在する場合は、まず元のレコードを削除してから新しいレコードを挿入します。

需要シナリオ:

このテーブルには、各顧客の最新の取引注文情報が格納されます。単一ユーザーのデータが重複して入力されないようにし、実行効率を最大化し、データベースとのやり取りを最小限に抑え、データベースの高可用性をサポートする必要があります。
このとき、「REPLACE INTO」ステートメントを使用すれば、最初にクエリを実行してから削除するかどうかを決定し、その後に挿入する必要がなくなります。

  • 「REPLACE INTO」ステートメントは、一意性 (存在) が一意のインデックスまたは主キーに基づくかどうかを決定します。
  • 「REPLACE INTO」ステートメントは、一意性 (存在) が一意のインデックスまたは主キーに基づくかどうかを決定します。
  • 「REPLACE INTO」ステートメントは、一意性 (存在) が一意のインデックスまたは主キーに基づくかどうかを決定します。

注: 次の SQL に示すように、ユーザー名フィールドに一意のインデックス (Unique) を作成し、transId を自動増分に設定する必要があります。

-- 20 ポイントの再チャージを last_transaction (transId,username,amount,trans_time,remark) に置き換えます 
  VALUES (null, 'chenhaha', 30, '2020-06-11 20:00:20', 'メンバーリチャージ');
 
-- 21 時にスキンを購入 REPLACE INTO last_transaction (transId, username, amount, trans_time, remark) 
  VALUES (null, 'chenhaha', 100, '2020-06-11 21:00:00', 'リー・シン・シュプリーム・フィストスキンを購入');

ユーザー名が「chenhaha」のレコードが存在しない場合は、REPLACE ステートメントによって新しいレコードが挿入されます (最初の再充電)。それ以外の場合は、ユーザー名が「chenhaha」の現在のレコードが削除され、新しいレコードが挿入されます。

特別なビジネス要件がない限り、ID に特定の値を指定しないでください。そうしないと、SQL の実行に影響します。

これで、MySQL で replace 関数を実装するためのいくつかの実用的なシナリオに関するこの記事は終了です。MySQL replace の実用的なシナリオに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • mysql はフィールドコンテンツの一部を置き換え、mysql は関数 replace() を置き換えます。
  • MySQL で置換操作を使用したときにデータ損失が発生する問題の解決策
  • MySQL での replace と replace into の使い方の説明
  • MySQL での置換例の詳細な説明
  • MySQL での正規表現置換のための replace と regexp の使用法の分析
  • フィールドの内容の一部を置き換えるには、mysql で replace を使用します。
  • MySQL の replace into ステートメントの使用方法の詳細な説明
  • MySQLの置換の使用法の簡単な分析
  • MYSQL バッチ置換における置換構文の使用の詳細な説明

<<:  JavaScript配列の重複排除のいくつかの方法についての詳細な説明

>>:  CSS3 を使用したテキスト折り紙効果のサンプルコード

推薦する

ポップアップ効果を実現するにはjsを使用します

この記事の例では、ポップアップ効果を実現するためのjsの具体的なコードを参考までに共有しています。具...

VueでTypescriptの設定手順を使用する

目次1. TypeScriptが古いVueプロジェクトに導入されるVue+Typescript プロ...

Docker を使用した Laravel アプリケーションのデプロイ例

この記事で使用されているPHPベースイメージはphp:7.3-apacheです。この記事の Lara...

Vueモバイル端末は左スライド編集と削除の全プロセスを実現します

序文プロジェクトのニーズに応じて、Vue-touch を使用して、vue モバイル端末の左スワイプ編...

Windows 8 での ssh コマンドの使用記録

1. 仮想マシンとgit bashウィンドウを開き、接続の準備をします2. 仮想マシンでifconf...

MySQL Group by最適化の詳細な説明

目次標準的な実行プロセス最適化並べ替えを削除並べ替え成し遂げる要約する標準の Group by ステ...

MySQL 8.0 アトミック DDL 構文の詳細な説明

目次01 アトミックDDLの紹介02 一部のDDL操作の実行動作の変更03 DDL 操作のログを表示...

Dockerは元のタグのイメージの再タグ付けと削除を実装します

docker イメージ ID は一意であり、イメージを物理的に識別できます。repository: ...

Webデザインチュートリアル(6):デザインへの情熱を持ち続ける

<br />前の記事:Webデザインチュートリアル(5):Webビジュアルデザイン。 1...

WeChatアプレットで計算機機能を実装する

この記事は、WeChat アプレットを使用して作成された簡単な計算機です。興味のある方はご覧ください...

Debian ベースの Linux システム ソフトウェア インストール コマンドの詳細な説明 (推奨)

Debian の紹介Debian は、広い意味では、フリーなオペレーティング システムの作成に専念...

Linuxのlocateコマンドの使い方

01. コマンドの概要実際には、locate コマンドは find -name の別の書き方ですが、...

JavaScriptで計算機機能を実現するプロセスの詳細な説明

目次1. 電卓機能の紹介2. 計算機ページのデザイン1. ナビゲーションバー2. データ部分3. i...

PSSHを使用してLinuxサーバーを一括管理する

pssh は、多数のマシンでのバッチ ssh 操作に使用される、Python で実装されたオープン ...