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 にプロジェクトをアップロードする方法

推薦する

Reactベースのコンポーネントのカプセル化の実装手順

目次序文antd はどのようにしてコンポーネントをカプセル化するのでしょうか?ディバイダーコンポーネ...

WeChatアプレットが計算機機能を実装

この記事では、WeChatアプレットの計算機機能を実装するための具体的なコードを参考までに紹介します...

MySQL 学習データベースバックアップの詳細な説明

目次1.DB、DBMS、SQL 2. データベースの特徴3. SQL分類4. MySQLを起動および...

Linuxの基本コマンドmktempの詳しい説明

mptemp は安全な方法で一時ファイルまたはディレクトリを作成します。このコマンドの適用範囲: R...

WeChatアプレットは記録機能を実装します

この記事では、WeChatアプレットのレコード機能を実装するための具体的なコードを参考までに紹介しま...

Linux 型バージョン メモリ ディスク クエリ コマンド紹介

1. まず、Linux システムのバージョン内容について概要を説明します。 1. カーネルバージョン...

UIエンジニアのキャリアについての私たちの考え

私は長い間落ち込んでいます、なぜでしょうか?以前、お客様から、提供されたソフトウェアが正常に動作しな...

雨滴効果を実現する JavaScript キャンバス

この記事では、雨滴効果を実現するためのJavaScriptキャンバスの具体的なコードを参考までに紹介...

MySQL での実行計画の詳細分析

序文効率的なSQL文の書き方は、Explain実行計画の分析と切り離せません。実行計画とは何か、効率...

redhat7 に yum 経由で mysql5.7.17 をインストールするチュートリアル

RHEL/CentOS シリーズの Linux オペレーティング システムには MySQL ソース自...

MySQLデータの同時更新を処理する方法

UPDATE はロックしますか?以下のような場合、SQL文はロックされますか? テーブル1を更新しま...

div タグ内の要素の margin-top が無効である場合の解決策

タイトル通りです。その質問は非常に奇妙です。要素の親タグはdivで、幅や高さなどの属性は設定されてい...

JS WebSocketを使用して簡単なチャットを実装する方法

目次ショートポーリングロングポーリングウェブソケットコミュニケーションの原則シンプルな1対1チャット...

React プロジェクトで eslint の Baidu スタイルを使用する詳細な説明

1. Baidu Eslint Ruleプラグインをインストールする npm i -D eslint...

Docker で Jenkins サービスを構築する例

画像をプルする root@EricZhou-MateBookProX: docker pull je...