MYSQLパターンマッチングREGEXPの使用に関する一般的な話など

MYSQLパターンマッチングREGEXPの使用に関する一般的な話など

のように

LIKE ではデータ全体が一致する必要がありますが、REGEXP では部分的な一致のみが必要です。
つまり、Like を使用するには、フィールドのすべての内容が条件を満たす必要がありますが、REGEXP では、条件を満たすフラグメントのみが必要です。

MySQL は、標準の SQL パターン マッチング (like) に加えて、vi、grep、sed などの Unix ユーティリティで使用されるものと同様の拡張正規表現パターン マッチングに基づく形式 (regexp) も提供します。
SQL パターン マッチングでは、任意の 1 文字に一致させるには「_」を使用し、任意の数の文字 (0 文字を含む) に一致させるには「%」を使用できます。 MySQL では、SQL モードはデフォルトで大文字と小文字を区別しません。以下にいくつかの例を示します。 SQL モードを使用する場合、= または != は使用できないことに注意してください。代わりに、LIKE または NOT LIKE 比較演算子を使用します。

「b」で始まる名前を検索するには:

mysql> SELECT * FROM pet WHERE name LIKE "b%";
+--------+---------+---------+----------+------------+------------+
| 名前 | 所有者 | 種 | 性別 | 生年月日 | 死亡日 |
+--------+---------+---------+----------+------------+------------+
| バフィー | ハロルド | 犬 | 女性 | 1989-05-13 | NULL |
| クッパ | ダイアン | 犬 | 男性 | 1989-08-31 | 1995-07-29 |
+--------+---------+---------+----------+------------+------------+

「fy」で終わる名前を検索するには:

mysql> SELECT * FROM pet WHERE name LIKE "%fy";
+--------+---------+---------+---------+---------+-------+
| 名前 | 所有者 | 種 | 性別 | 生年月日 | 死亡日 |
+--------+---------+---------+---------+---------+-------+
| ふわふわ | ハロルド | 猫 | f | 1993-02-04 | NULL |
| バフィー | ハロルド | 犬 | 女性 | 1989-05-13 | NULL |
+--------+---------+---------+---------+---------+-------+

「w」を含む名前を検索するには:

mysql> SELECT * FROM pet WHERE name LIKE "%w%";
+----------+--------+---------+----------+------------+------------+
| 名前 | 所有者 | 種 | 性別 | 生年月日 | 死亡日 |
+----------+--------+---------+----------+------------+------------+
| 爪 | グウェン | 猫 | m | 1994-03-17 | NULL |
| クッパ | ダイアン | 犬 | 男性 | 1989-08-31 | 1995-07-29 |
| ウィスラー | グウェン | 鳥 | NULL | 1997-12-09 | NULL |
+----------+--------+---------+----------+------------+------------+

ちょうど 5 文字を含む名前を検索するには、「_」パターン文字を使用します。

mysql> SELECT * FROM pet WHERE name LIKE "_____";
+-------+---------+---------+----------+--------+-------+
| 名前 | 所有者 | 種 | 性別 | 生年月日 | 死亡日 |
+-------+---------+---------+----------+--------+-------+
| 爪 | グウェン | 猫 | m | 1994-03-17 | NULL |
| バフィー | ハロルド | 犬 | 女性 | 1989-05-13 | NULL |
+-------+---------+---------+----------+--------+-------+

正規表現

別の種類のマッチングは正規表現に基づいています。このようなパターンの一致をテストする場合は、REGEXP 演算子と NOT REGEXP 演算子 (または同義語の RLIKE と NOT RLIKE) を使用します。

「.」は任意の 1 文字に一致します。

文字クラス "[...]" は、角括弧内の任意の文字に一致します。たとえば、「[abc]」は「a」、「b」、または「c」に一致します。文字の範囲に名前を付けるには、「-」を使用します。 "[az]" は任意の小文字に一致し、"[0-9]" は任意の数字に一致します。
「 * 」は、その前に続く 0 個以上の文字と一致します。たとえば、「x*」は任意の数の「x」文字に一致し、「[0-9]*」は任意の数の数字に一致し、「.*」は任意の数の任意の文字に一致します。

正規表現では大文字と小文字が区別されますが、必要に応じて文字クラスを使用して両方を一致させることもできます。たとえば、「[aA]」は小文字または大文字の「a」に一致し、「[a-zA-Z]」は大文字と小文字のどちらの文字にも一致します。

パターンは、テスト対象の値のどこかに出現する場合に一致します (SQL パターンは、値全体が一致する限り一致します)。
テストする値の先頭または末尾に一致するようにパターンを配置するには、パターンの先頭に「^」を使用するか、パターンの末尾に「$」を使用します。
拡張正規表現がどのように機能するかを説明するために、上記の LIKE クエリを REGEXP を使用して以下のように書き換えます。
「b」で始まる名前を検索するには、名前の先頭に一致するように「^」を使用し、小文字または大文字の「b」に一致するように「[bB]」を使用します。

mysql> SELECT * FROM pet WHERE name REGEXP "^[bB]";
+--------+---------+---------+----------+------------+------------+
| 名前 | 所有者 | 種 | 性別 | 生年月日 | 死亡日 |
+--------+---------+---------+----------+------------+------------+
| バフィー | ハロルド | 犬 | 女性 | 1989-05-13 | NULL |
| クッパ | ダイアン | 犬 | 男性 | 1989-08-31 | 1995-07-29 |
+--------+---------+---------+----------+------------+------------+

「fy」で終わる名前を検索するには、名前の末尾に一致する「$」を使用します。

mysql> SELECT * FROM pet WHERE name REGEXP "fy$";
+--------+---------+---------+---------+---------+-------+
| 名前 | 所有者 | 種 | 性別 | 生年月日 | 死亡日 |
+--------+---------+---------+---------+---------+-------+
| ふわふわ | ハロルド | 猫 | f | 1993-02-04 | NULL |
| バフィー | ハロルド | 犬 | 女性 | 1989-05-13 | NULL |
+--------+---------+---------+---------+---------+-------+

「w」を含む名前を検索するには、小文字または大文字の「w」に一致する「[wW]」を使用します。

mysql> SELECT * FROM pet WHERE name REGEXP "[wW]";
+----------+--------+---------+----------+------------+------------+
| 名前 | 所有者 | 種 | 性別 | 生年月日 | 死亡日 |
+----------+--------+---------+----------+------------+------------+
| 爪 | グウェン | 猫 | m | 1994-03-17 | NULL |
| クッパ | ダイアン | 犬 | 男性 | 1989-08-31 | 1995-07-29 |
| ウィスラー | グウェン | 鳥 | NULL | 1997-12-09 | NULL |
+----------+--------+---------+----------+------------+------------+

[^……]は[]に含まれない文字と一致します。例えば、w/z/sで始まる名前を検索します。

テーブル名から名前を選択します。名前の正規表現は '^[^wzs]' です。

*、0回以上繰り返される、JavaScriptの正規表現に精通している学生は知っている

'str*' は st/str/strr/strrr に一致します...

?、0回または1回繰り返す

'str?' は st/str に一致します

+、1回以上繰り返す

'str+' は str/strr/strrr/strrrr に一致します...

JavaScript の正規表現と比較すると、ここでの正規表現は簡略化されたバージョンです。遅延一致/貪欲一致はありません。[] では \w\s\d の構文はサポートされておらず、中国語はサポートされていません。比較的単純です

MYSQL パターン マッチング REGEXP の使用法に関する上記の記事は、エディターが皆さんと共有する内容のすべてです。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQLの最適化の詳細な分析とパフォーマンス
  • Mysql | ワイルドカード(%、_ など)を使用したファジークエリの詳細な説明
  • MySQL ファジークエリ LIKE と REGEXP の使用に関する詳細な紹介
  • 複数キーワード検索を実現する PHP MySQL のような方法
  • MySQL でのテーブルレプリケーション: create table like および create table as select
  • mysql のようなクエリ文字列の例文
  • mysql 正規表現 LIKE ワイルドカード
  • MySQLのファジークエリのような遅い速度を解決する方法

<<:  VmWareでcentos7をインストールするときにインターネットにアクセスできない問題の解決策

>>:  Linux システムで Code Cloud にプロジェクトをアップロードする方法

推薦する

Ubuntu 16.04 64 ビット版の VMware Tools のインストールと構成のグラフィック チュートリアル

この記事では、VMware Toolsのインストールと構成に関するグラフィックチュートリアルを参考と...

MySQL の文字セット utf8 を utf8mb4 に変更する方法

MySQL 5.5 の場合、文字セットが設定されていない場合、MySQL のデフォルトの文字セットは...

Eclipseを使用してMySQLデータベースに接続する方法を説明します

序文常にエラーが発生するため、MySQL データベースに接続するプロセスを記録します。接続プロセス1...

MySQL の完全なデータベース バックアップ データを使用して単一のテーブル データを復元する方法

序文データベースをバックアップするときは、データベース全体のバックアップを使用します。ただし、何らか...

MySQL データベースを最適化する 8 つの方法の詳細な説明 (必読の定番)

導入:インターネット上にはデータベースの最適化に関する情報や方法が数多くありますが、その多くは品質に...

vue-cli を使用してプロジェクトを作成し、webpack でパッケージ化する方法

1. 環境を準備する(Node.jsをダウンロードし、環境変数を設定する) 2. vue-cliをグ...

Ajax は CORS レスポンス ヘッダーを設定してクロスドメインの問題を解決し、クロスドメインのケース スタディを実現します。

1. クロスドメインを実現するためにCORSレスポンスヘッダーを設定するクロスオリジンリソース共有...

一般的な HTTP ステータス コード 10 個の詳細な説明

HTTP ステータス コードは、Web サーバーの HTTP 応答ステータスを示すために使用される ...

Jsモジュールパッケージのエクスポートの使用法と違いにはインポートが必要

目次1. Commonjsのエクスポートとrequireの使用1.1 CommonJS エクスポート...

Vueはデータを初期状態にリセットします

場合によっては、データ内のデータを再利用する必要がありますが、データ内のデータはさまざまなフォーム、...

Pythonは出力をcsv操作に書き込む

以下のように表示されます。 def test_write(self): フィールド=[] field...

JavaScript でのカスタム スワイパー コンポーネントの詳細な説明

目次エフェクト表示コンポーネント設定ステップ1ステップ2ステップ3コンポーネントの使用ステップ1ステ...

HTML マークアップ言語 - フォーム

123WORDPRESS.COM HTML チュートリアル セクションに戻るには、ここをクリックして...

Dockerサーバーのストレージリソースプール不足問題の解決

目次1. 問題の説明2. 問題分析3. 問題解決1. Dockerのディスク使用量を確認する2. 再...

大きな太陽の天気アイコンを純粋な CSS で記述する方法の例

効果効果図は以下のとおりです実装のアイデアDivは太陽の長方形の光と影を実現します前の疑似要素は、既...