国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

MySQL數(shù)據(jù)庫——MySQL REGEXP:正則表達(dá)式

這篇具有很好參考價(jià)值的文章主要介紹了MySQL數(shù)據(jù)庫——MySQL REGEXP:正則表達(dá)式。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

正則表達(dá)式主要用來查詢和替換符合某個(gè)模式(規(guī)則)的文本內(nèi)容。例如,從一個(gè)文件中提取電話號(hào)碼,查找一篇文章中重復(fù)的單詞、替換文章中的敏感語匯等,這些地方都可以使用正則表達(dá)式。正則表達(dá)式強(qiáng)大且靈活,常用于非常復(fù)雜的查詢。

MySQL 中,使用?REGEXP?關(guān)鍵字指定正則表達(dá)式的字符匹配模式,其基本語法格式如下:

屬性名 REGEXP '匹配方式'

其中,“屬性名”表示需要查詢的字段名稱;“匹配方式”表示以哪種方式來匹配查詢。“匹配方式”中有很多的模式匹配字符,它們分別表示不同的意思。下表列出了 REGEXP 操作符中常用的匹配方式。

選項(xiàng) 說明 例子 匹配值示例
^ 匹配文本的開始字符 '^b' 匹配以字母 b 開頭的字符串 book、big、banana、bike
$ 匹配文本的結(jié)束字符 'st$' 匹配以 st 結(jié)尾的字符串 test、resist、persist
. 匹配任何單個(gè)字符 'b.t' 匹配任何?b 和 t 之間有一個(gè)字符 bit、bat、but、bite
* 匹配零個(gè)或多個(gè)在它前面的字符 'f*n' 匹配字符 n 前面有任意個(gè)字符 f fn、fan、faan、abcn
+ 匹配前面的字符 1 次或多次 'ba+' 匹配以 b 開頭,后面至少緊跟一個(gè) a ba、bay、bare、battle
<字符串> 匹配包含指定字符的文本 'fa' 匹配包含‘fa’的文本 fan、afa、faad
[字符集合] 匹配字符集合中的任何一個(gè)字符 '[xz]' 匹配 x 或者 z dizzy、zebra、x-ray、extra
[^] 匹配不在括號(hào)中的任何字符 '[^abc]' 匹配任何不包含 a、b 或 c 的字符串 desk、fox、f8ke
字符串{n,} 匹配前面的字符串至少 n 次 'b{2}' 匹配 2 個(gè)或更多的 b bbb、bbbb、bbbbbbb
字符串
{n,m}
匹配前面的字符串至少 n 次, 至多 m 次 'b{2,4}' 匹配最少 2 個(gè),最多 4 個(gè) b bbb、bbbb

MySQL 中的正則表達(dá)式與 Java 語言、PHP 語言等編程語言中的正則表達(dá)式基本一致。

查詢以特定字符或字符串開頭的記錄

字符^用來匹配以特定字符或字符串開頭的記錄。

例 1

在 tb_students_info 表中,查詢 name 字段以“J”開頭的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info 
    -> WHERE name REGEXP '^J';
+----+------+------+------+--------+-----------+
| id | name | age  | sex  | height | course_id |
+----+------+------+------+--------+-----------+
|  4 | Jane |   22 | 男   |    162 |         3 |
|  5 | Jim  |   24 | 女   |    175 |         2 |
|  6 | John |   21 | 女   |    172 |         4 |
+----+------+------+------+--------+-----------+
3 rows in set (0.01 sec)

例 2

在 tb_students_info 表中,查詢 name 字段以“Ji”開頭的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP '^Ji';
+----+------+------+------+--------+-----------+
| id | name | age  | sex  | height | course_id |
+----+------+------+------+--------+-----------+
|  5 | Jim  |   24 | 女   |    175 |         2 |
+----+------+------+------+--------+-----------+
1 row in set (0.00 sec)

查詢以特定字符或字符串結(jié)尾的記錄

字符$用來匹配以特定字符或字符串結(jié)尾的記錄。

例 3

在 tb_students_info 表中,查詢 name 字段以“y”結(jié)尾的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP 'y$';
+----+-------+------+------+--------+-----------+
| id | name  | age  | sex  | height | course_id |
+----+-------+------+------+--------+-----------+
|  1 | Dany  |   25 | 男   |    160 |         1 |
|  3 | Henry |   23 | 女   |    185 |         1 |
|  7 | Lily  |   22 | 男   |    165 |         4 |
+----+-------+------+------+--------+-----------+
3 rows in set (0.00 sec)

例 4

在 tb_students_info 表中,查詢 name 字段以“ry”結(jié)尾的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP 'ry$';
+----+-------+------+------+--------+-----------+
| id | name  | age  | sex  | height | course_id |
+----+-------+------+------+--------+-----------+
|  3 | Henry |   23 | 女   |    185 |         1 |
+----+-------+------+------+--------+-----------+
1 row in set (0.00 sec)

替代字符串中的任意一個(gè)字符

字符.用來替代字符串中的任意一個(gè)字符。

例 5

在 tb_students_info 表中,查詢 name 字段值包含“a”和“y”,且兩個(gè)字母之間只有一個(gè)字母的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP 'a.y';
+----+------+------+------+--------+-----------+
| id | name | age  | sex  | height | course_id |
+----+------+------+------+--------+-----------+
|  1 | Dany |   25 | 男   |    160 |         1 |
+----+------+------+------+--------+-----------+
1 row in set (0.00 sec)

匹配多個(gè)字符

字符*+都可以匹配多個(gè)該符號(hào)之前的字符。不同的是,+表示至少一個(gè)字符,而*可以表示 0 個(gè)字符。

例 6

在 tb_students_info 表中,查詢 name 字段值包含字母“T”,且“T”后面出現(xiàn)字母“h”的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP '^Th*';
+----+--------+------+------+--------+-----------+
| id | name   | age  | sex  | height | course_id |
+----+--------+------+------+--------+-----------+
|  9 | Thomas |   22 | 女   |    178 |         5 |
| 10 | Tom    |   23 | 女   |    165 |         5 |
+----+--------+------+------+--------+-----------+
2 rows in set (0.00 sec)

例 7

在 tb_students_info 表中,查詢 name 字段值包含字母“T”,且“T”后面至少出現(xiàn)“h”一次的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP '^Th+';
+----+--------+------+------+--------+-----------+
| id | name   | age  | sex  | height | course_id |
+----+--------+------+------+--------+-----------+
|  9 | Thomas |   22 | 女   |    178 |         5 |
+----+--------+------+------+--------+-----------+
1 row in set (0.00 sec)

匹配指定字符串

正則表達(dá)式可以匹配字符串。當(dāng)表中的記錄包含這個(gè)字符串時(shí),就可以將該記錄查詢出來。指定多個(gè)字符串時(shí),需要用|隔開。只要匹配這些字符串中的任意一個(gè)即可。

例 8

在 tb_students_info 表中,查詢 name 字段值包含字符串“an”的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP 'an';
+----+-------+------+------+--------+-----------+
| id | name  | age  | sex  | height | course_id |
+----+-------+------+------+--------+-----------+
|  1 | Dany  |   25 | 男   |    160 |         1 |
|  4 | Jane  |   22 | 男   |    162 |         3 |
|  8 | Susan |   23 | 男   |    170 |         5 |
+----+-------+------+------+--------+-----------+
3 rows in set (0.00 sec)

例 9

在 tb_students_info 表中,查詢 name 字段值包含字符串“an”或“en”的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP 'an|en';
+----+-------+------+------+--------+-----------+
| id | name  | age  | sex  | height | course_id |
+----+-------+------+------+--------+-----------+
|  1 | Dany  |   25 | 男   |    160 |         1 |
|  2 | Green |   23 | 男   |    158 |         2 |
|  3 | Henry |   23 | 女   |    185 |         1 |
|  4 | Jane  |   22 | 男   |    162 |         3 |
|  8 | Susan |   23 | 男   |    170 |         5 |
+----+-------+------+------+--------+-----------+
5 rows in set (0.00 sec)

注意:字符串與|之間不能有空格。因?yàn)?,查詢過程中,數(shù)據(jù)庫系統(tǒng)會(huì)將空格也當(dāng)作一個(gè)字符,這樣就查詢不出想要的結(jié)果。

匹配指定字符串中的任意一個(gè)

使用方括號(hào)[ ]可以將需要查詢的字符組成一個(gè)字符集合。只要記錄中包含方括號(hào)中的任意字符,該記錄就會(huì)被查詢出來。例如,通過“[abc]”可以查詢包含 a、b 和 c 等 3 個(gè)字母中任意一個(gè)的記錄。

例 10

在 tb_students_info 表中,查詢 name 字段值包含字母“i”或“o”的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP '[io]';
+----+--------+------+------+--------+-----------+
| id | name   | age  | sex  | height | course_id |
+----+--------+------+------+--------+-----------+
|  5 | Jim    |   24 | 女   |    175 |         2 |
|  6 | John   |   21 | 女   |    172 |         4 |
|  7 | Lily   |   22 | 男   |    165 |         4 |
|  9 | Thomas |   22 | 女   |    178 |         5 |
| 10 | Tom    |   23 | 女   |    165 |         5 |
| 11 | LiMing |   22 | 男   |    180 |         7 |
+----+--------+------+------+--------+-----------+
6 rows in set (0.00 sec)

從查詢結(jié)果可以看到,所有返回記錄的 name 字段值都包含字母 i 或 o,或者兩個(gè)都有。

方括號(hào)[ ]還可以指定集合的區(qū)間。例如,“[a-z]”表示從 a~z 的所有字母;“[0-9]”表示從 0~9 的所有數(shù)字;“[a-z0-9]”表示包含所有的小寫字母和數(shù)字;“[a-zA-Z]”表示匹配所有字符。

例 11

在 tb_students_info 表中,查詢 name 字段值中包含 1、2 或 3 的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP '[123]';
Empty set (0.00 sec)

匹配集合“[123]”也可以寫成“[1-3]”,即指定集合區(qū)間。

匹配指定字符以外的字符

[^字符集合]用來匹配不在指定集合中的任何字符。

例 12

在 tb_students_info 表中,查詢 name 字段值包含字母 a~t 以外的字符的記錄,SQL 語句和執(zhí)行過程如下:

mysql> SELECT * FROM tb_students_info
    -> WHERE name REGEXP '[^a-t]' ;
+----+-------+------+------+--------+-----------+
| id | name  | age  | sex  | height | course_id |
+----+-------+------+------+--------+-----------+
|  1 | Dany  |   25 | 男   |    160 |         1 |
|  3 | Henry |   23 | 女   |    185 |         1 |
|  7 | Lily  |   22 | 男   |    165 |         4 |
|  8 | Susan |   23 | 男   |    170 |         5 |
+----+-------+------+------+--------+-----------+
4 rows in set (0.00 sec)

使用{n,}或者{n,m}來指定字符串連續(xù)出現(xiàn)的次數(shù)

字符串{n,}表示字符串連續(xù)出現(xiàn) n 次;字符串{n,m}表示字符串連續(xù)出現(xiàn)至少 n 次,最多 m 次。

例如,a{2,} 表示字母 a 連續(xù)出現(xiàn)至少 2 次,也可以大于 2 次;a{2,4} 表示字母 a 連續(xù)出現(xiàn)最少 2 次,最多不能超過 4 次。

例 13

在 tb_students_info 表中,查詢 name 字段值出現(xiàn)字母‘e’ 至少 2 次的記錄,SQL 語句如下:

mysql> SELECT * FROM tb_students_info WHERE name REGEXP 'e{2,}';
+----+-------+------+------+--------+-----------+
| id | name  | age  | sex  | height | course_id |
+----+-------+------+------+--------+-----------+
|  2 | Green |   23 | 男   |    158 |         2 |
+----+-------+------+------+--------+-----------+
1 row in set (0.00 sec)

例 14

在 tb_students_info 表中,查詢 name 字段值出現(xiàn)字符串“i” 最少 1 次,最多 3 次的記錄,SQL 語句如下:

mysql> SELECT * FROM tb_students_info WHERE name REGEXP 'i{1,3}';
+----+--------+------+------+--------+-----------+
| id | name   | age  | sex  | height | course_id |
+----+--------+------+------+--------+-----------+
|  5 | Jim    |   24 | 女   |    175 |         2 |
|  7 | Lily   |   22 | 男   |    165 |         4 |
| 11 | LiMing |   22 | 男   |    180 |         7 |
+----+--------+------+------+--------+-----------+
3 rows in set (0.00 sec)

黑馬程序員 MySQL數(shù)據(jù)庫入門到精通,從mysql安裝到mysql高級(jí)、mysql優(yōu)化全囊括文章來源地址http://www.zghlxwxcb.cn/news/detail-430097.html

到了這里,關(guān)于MySQL數(shù)據(jù)庫——MySQL REGEXP:正則表達(dá)式的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • Oracle 正則表達(dá)式詳解(regexp_substr、regexp_instr、regexp_replace、regexp_like)

    文章目錄 1 概述 2 匹配規(guī)則 3 正則函數(shù) 3.1 regexp_substr() 3.2 regexp_instr() 3.3 regexp_replace() 3.4 regexp_like() 1 概述 1. 作用:處理字符時(shí),很強(qiáng)大 1 2. 分類:與下列相似,但功能更加強(qiáng)大(‘支持正則表達(dá)式’) (1) regexp_like : 同 like 功能相似(模糊 ‘匹配’) (2) regexp_instr : 同 instr 功

    2024年02月09日
    瀏覽(24)
  • RegExp正則表達(dá)式左限定右限定左右限定,預(yù)查詢,預(yù)查尋,斷言 : (?<= , (?= , (?<! , (?!

    RegExp正則表達(dá)式左限定右限定左右限定,預(yù)查詢,預(yù)查尋,斷言 : (?<= , (?= , (?<! , (?!

    (?= , (?= , (?! , (?! 有好多種稱呼 , 我稱為: 左限定, 右限定, 左否定, 右否定 (?=左限定) ?? (?=右限定) (?!左否定) ?? (?!右限定) 再提煉 ?= ?? ?= ?! ?? ?! 其它的稱呼 正則表達(dá)式預(yù)查尋分為 4 種: 正向肯定預(yù)查: (?=pattern) (?=pattern) 正向否定預(yù)查: (?!pattern) (?!pattern) 反向肯定預(yù)查

    2024年02月20日
    瀏覽(17)
  • Oracle使用regexp_like報(bào)錯(cuò)ORA-12733 正則表達(dá)式太長(zhǎng)

    注:此篇內(nèi)容并沒有解決正則表達(dá)式太長(zhǎng)的問題。 在命令行窗口連接數(shù)據(jù)庫: 其中: username ?是你的數(shù)據(jù)庫用戶名。 password ?是你的數(shù)據(jù)庫密碼。 hostname ?是數(shù)據(jù)庫服務(wù)器的主機(jī)名或IP地址。 port ?是監(jiān)聽端口,默認(rèn)是1521。 SID ?是系統(tǒng)標(biāo)識(shí)符,是數(shù)據(jù)庫實(shí)例的唯一名稱。

    2024年04月15日
    瀏覽(16)
  • VBA提高篇_ 31 VBA調(diào)用正則表達(dá)式_RegExp.Pattern/Global/Execute(s)/Replace(s,r)

    VBA提高篇_ 31 VBA調(diào)用正則表達(dá)式_RegExp.Pattern/Global/Execute(s)/Replace(s,r)

    RegExp對(duì)象: 屬于外部對(duì)象,對(duì)應(yīng)的變量需要聲明為Object對(duì)象,并使用CreateObject函數(shù)創(chuàng)建 用于創(chuàng)建各種外部對(duì)象,只要將該對(duì)象的完整類名作為參數(shù)(字符串形式),即可返回一個(gè)該類的對(duì)象 例: CreateObject(“word.application”),返回一個(gè)微軟的word對(duì)象,用于打開和修改Word對(duì)象 結(jié)果存入在M

    2024年02月09日
    瀏覽(32)
  • MySQL正則表達(dá)式檢索數(shù)據(jù)

    MySQL正則表達(dá)式檢索數(shù)據(jù)

    目錄 一、使用正則表達(dá)式進(jìn)行基本字符匹配 1.使用regexp 2.使用正則表達(dá)式? .? 二、進(jìn)行OR匹配 1.為搜索兩個(gè)串之一,使用? ?|?? 2.匹配幾個(gè)字符之一[] 3.匹配范圍 ?4.匹配特殊字符 過濾數(shù)據(jù)允許使用 匹配、比較、通配符 操作來尋找數(shù)據(jù),但是隨著過濾條件的復(fù)雜性增

    2024年02月14日
    瀏覽(24)
  • MySQL正則表達(dá)式 | 事務(wù)詳解

    MySQL正則表達(dá)式 | 事務(wù)詳解

    目錄 一、正則表達(dá)式 實(shí)例操作 二、事務(wù) 事務(wù)控制語句 MYSQL 事務(wù)處理主要有兩種方法 SQL測(cè)試代碼 PHP中使用事務(wù)實(shí)例 使用保留點(diǎn) SAVEPOINT MySQL可以通過? LIKE ...% ?來進(jìn)行模糊匹配。 MySQL 同樣也支持其他正則表達(dá)式的匹配, MySQL中使用 REGEXP 操作符來進(jìn)行正則表達(dá)式匹配。 如果

    2023年04月18日
    瀏覽(17)
  • mysql 正則表達(dá)式 提取 指定字符

    mysql 正則表達(dá)式 提取 指定字符

    eg: 使用正則表達(dá)式來進(jìn)行匹配替換: REGEXP_REPLACE(\\\'需要進(jìn)行替換的字段‘, ‘被替換的’,‘替換的內(nèi)容’) eg: 模式 說明 ^ 匹配輸入字符串的開始位置。如果設(shè)置了 RegExp 對(duì)象的 Multiline 屬性,^ 也匹配 ‘n’ 或 ‘r’ 之后的位置。 $ 匹配輸入字符串的結(jié)束位置。

    2024年02月06日
    瀏覽(28)
  • c# 從零到精通 數(shù)據(jù)庫 定義LINQ查詢表達(dá)式,從數(shù)組中查找長(zhǎng)度小于7的所有項(xiàng)

    c# 從零到精通 數(shù)據(jù)庫 定義LINQ查詢表達(dá)式,從數(shù)組中查找長(zhǎng)度小于7的所有項(xiàng)

    c# 從零到精通 數(shù)據(jù)庫 定義LINQ查詢表達(dá)式,從數(shù)組中查找長(zhǎng)度小于7的所有項(xiàng) using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace LINQQuery { class Program { static void Main(string[] args) { //定義一個(gè)字符串?dāng)?shù)組 string[] strName = new string[] { “明日科技”,“C#編程詞典”

    2024年02月10日
    瀏覽(22)
  • 【MySQL】不允許你不會(huì)用正則表達(dá)式進(jìn)行搜索

    【MySQL】不允許你不會(huì)用正則表達(dá)式進(jìn)行搜索

    ?? 博客主頁:博主鏈接 ?? 本文由 M malloc 原創(chuàng),首發(fā)于 CSDN?? ?? 學(xué)習(xí)專欄推薦:LeetCode刷題集! ?? 歡迎點(diǎn)贊 ?? 收藏 ?留言 ?? 如有錯(cuò)誤敬請(qǐng)指正! ?? 未來很長(zhǎng),值得我們?nèi)Ρ几案篮玫纳? ??大家好呀,今天是我第N次寫MySQL,也是最近才學(xué)習(xí)MySQL,也想著記錄

    2024年02月11日
    瀏覽(18)
  • 機(jī)器學(xué)習(xí)與數(shù)據(jù)科學(xué)-專題1 Python正則表達(dá)式-【正則表達(dá)式入門-1】

    機(jī)器學(xué)習(xí)與數(shù)據(jù)科學(xué)-專題1 Python正則表達(dá)式-【正則表達(dá)式入門-1】

    為了完成本關(guān)任務(wù),你需要掌握: 在 Python 中使用正則表達(dá)式; 最基礎(chǔ)正則表達(dá)式; 正則匹配函數(shù)。 在 Python 中使用正則表達(dá)式 正可謂人生苦短,我用 Python。Python 有個(gè)特點(diǎn)就是庫非常多,自然擁有正則匹配這種常見的庫,并且此庫已經(jīng)嵌入在 Python 標(biāo)準(zhǔn)庫中,使用起來非常

    2024年01月22日
    瀏覽(109)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包