亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL 字符串模式匹配 擴展正則表達式模式匹配

2020-01-19 00:16:21
字體:
來源:轉載
供稿:網友

標準的SQL模式匹配

SQL的模式匹配允許你使用“_”匹配任何單個字符,而“%”匹配任意數目字符(包括零個字符)。在 MySQL中,SQL的模式缺省是忽略大小寫的。下面顯示一些例子。注意在你使用SQL模式時,你不能使用=或!=;而使用LIKE或NOT LIKE比較操作符。

例如,在表pet中,為了找出以“b”開頭的名字:

mysql> SELECT * FROM pet WHERE name LIKE "b%";

+--------+--------+---------+------+------------+------------+

| name   | owner | species | sex | birth      | death      |

+--------+--------+---------+------+------------+------------+

| Buffy | Harold | dog     | f    | 1989-05-13 | NULL       |

| Bowser | Diane | dog     | m    | 1989-08-31 | 1995-07-29 |

+--------+--------+---------+------+------------+------------+

為了找出以“fy”結尾的名字:

mysql> SELECT * FROM pet WHERE name LIKE "%fy";

+--------+--------+---------+------+------------+-------+

| name   | owner | species | sex | birth      | death |

+--------+--------+---------+------+------------+-------+

| Fluffy | Harold | cat     | f    | 1993-02-04 | NULL |

| Buffy | Harold | dog     | f    | 1989-05-13 | NULL |

+--------+--------+---------+------+------------+-------+

為了找出包含一個“w”的名字:

mysql> SELECT * FROM pet WHERE name LIKE "%w%";

+----------+-------+---------+------+------------+------------+

| name     | owner | species | sex | birth      | death      |

+----------+-------+---------+------+------------+------------+

| Claws    | Gwen | cat     | m    | 1994-03-17 | NULL       |

| Bowser   | Diane | dog     | m    | 1989-08-31 | 1995-07-29 |

| Whistler | Gwen | bird    | NULL | 1997-12-09 | NULL       |

+----------+-------+---------+------+------------+------------+

為了找出包含正好5個字符的名字,使用“_”模式字符:

mysql> SELECT * FROM pet WHERE name LIKE "_____";

+-------+--------+---------+------+------------+-------+

| name | owner | species | sex | birth      | death |

+-------+--------+---------+------+------------+-------+

| Claws | Gwen   | cat     | m    | 1994-03-17 | NULL |

| Buffy | Harold | dog     | f    | 1989-05-13 | NULL |

+-------+--------+---------+------+------------+-------+

MySQL提供標準的SQL模式匹配,以及一種基于象Unix實用程序如vi、grep和sed的擴展正則表達式模式匹配的格式。

擴展正則表達式模式匹配

由MySQL提供的模式匹配的其他類型是使用擴展正則表達式。當你對這類模式進行匹配測試時,使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它們是同義詞)。

擴展正則表達式的一些字符是:

“.”匹配任何單個的字符。

一個字符類“[...]”匹配在方括號內的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。為了命名字符的一個范圍,使用一個“-”。

“[a-z]”匹配任何小寫字母,而“[0-9]”匹配任何數字。

“ * ”匹配零個或多個在它前面的東西。例如,“x*”匹配任何數量的“x”字符,“[0-9]*”匹配的任何數量的數字,而“.*”匹配任何數量的任何東西。

正則表達式是區分大小寫的,但是如果你希望,你能使用一個字符類匹配兩種寫法。例如,“[aA]”匹配小寫或大寫的“a”而“[a-zA-Z]”匹配兩種寫法的任何字母。

如果它出現在被測試值的任何地方,模式就匹配(只要他們匹配整個值,SQL模式匹配)。

為了定位一個模式以便它必須匹配被測試值的開始或結尾,在模式開始處使用“^”或在模式的結尾用“$”。

為了說明擴展正則表達式如何工作,上面所示的LIKE查詢在下面使用REGEXP重寫:

為了找出以“b”開頭的名字,使用“^”匹配名字的開始并且“[bB]”匹配小寫或大寫的“b”:

mysql> SELECT * FROM pet WHERE name REGEXP "^[bB]";

+--------+--------+---------+------+------------+------------+

| name   | owner | species | sex | birth      | death      |

+--------+--------+---------+------+------------+------------+

| Buffy | Harold | dog     | f    | 1989-05-13 | NULL       |

| Bowser | Diane | dog     | m    | 1989-08-31 | 1995-07-29 |

+--------+--------+---------+------+------------+------------+

為了找出以“fy”結尾的名字,使用“$”匹配名字的結尾:

mysql> SELECT * FROM pet WHERE name REGEXP "fy$";

+--------+--------+---------+------+------------+-------+

| name   | owner | species | sex | birth      | death |

+--------+--------+---------+------+------------+-------+

| Fluffy | Harold | cat     | f    | 1993-02-04 | NULL |

| Buffy | Harold | dog     | f    | 1989-05-13 | NULL |

+--------+--------+---------+------+------------+-------+

為了找出包含一個“w”的名字,使用“[wW]”匹配小寫或大寫的“w”:

mysql> SELECT * FROM pet WHERE name REGEXP "[wW]";

+----------+-------+---------+------+------------+------------+

| name     | owner | species | sex | birth      | death      |

+----------+-------+---------+------+------------+------------+

| Claws    | Gwen | cat     | m    | 1994-03-17 | NULL       |

| Bowser   | Diane | dog     | m    | 1989-08-31 | 1995-07-29 |

| Whistler | Gwen | bird    | NULL | 1997-12-09 | NULL       |

+----------+-------+---------+------+------------+------------+

既然如果一個正規表達式出現在值的任何地方,其模式匹配了,就不必再先前的查詢中在模式的兩方面放置一個通配符以使得它匹配整個值,

就像如果你使用了一個SQL模式那樣。

為了找出包含正好5個字符的名字,使用“^”和“$”匹配名字的開始和結尾,和5個“.”實例在兩者之間:

mysql> SELECT * FROM pet WHERE name REGEXP "^.....$";

+-------+--------+---------+------+------------+-------+

| name | owner | species | sex | birth      | death |

+-------+--------+---------+------+------------+-------+

| Claws | Gwen   | cat     | m    | 1994-03-17 | NULL |

| Buffy | Harold | dog     | f    | 1989-05-13 | NULL |

+-------+--------+---------+------+------------+-------+

你也可以使用“{n}”“重復n次”操作符重寫先前的查詢:

mysql> SELECT * FROM pet WHERE name REGEXP "^.{5}$";

+-------+--------+---------+------+------------+-------+

| name | owner | species | sex | birth      | death |

+-------+--------+---------+------+------------+-------+

| Claws | Gwen   | cat     | m    | 1994-03-17 | NULL |

| Buffy | Harold | dog     | f    | 1989-05-13 | NULL |

+-------+--------+---------+------+------------+-------+

總結

本介紹了有關字符串模式匹配的有關知識。標準的SQL模式匹配是SQL語言的標準,可以被其它關系數據庫系統接受。擴展正規表達式模式匹配

是根據Unix系統的標準開發了,一般只可使用在MySQL上,但是其功能要比標準的SQL模式匹配更強。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一区第二区| 欧美黄色小视频| 久久久久久尹人网香蕉| 欧美在线精品免播放器视频| 日韩a**中文字幕| 日本三级韩国三级久久| 日本不卡视频在线播放| 久久精品欧美视频| 亚洲欧洲日产国码av系列天堂| 日韩免费看的电影电视剧大全| 国产精品免费网站| 亚洲欧美日韩国产中文| 久久影视电视剧免费网站清宫辞电视| 久久影视电视剧凤归四时歌| 久久亚洲欧美日韩精品专区| 日韩中文视频免费在线观看| 欧美激情视频给我| 久久成人一区二区| 国语自产精品视频在免费| 亚洲国产精品久久久| 国产在线观看91精品一区| 欧美成人第一页| 国产成人一区二区三区小说| 伊人伊人伊人久久| 疯狂做受xxxx欧美肥白少妇| 中日韩美女免费视频网站在线观看| 精品一区二区三区四区在线| 亚洲自拍欧美色图| 91精品久久久久久久久中文字幕| 国产精品mp4| 亚洲国产精彩中文乱码av在线播放| 亚洲精品国产精品乱码不99按摩| 亚洲人高潮女人毛茸茸| 日韩精品极品在线观看| 97成人精品区在线播放| 成人有码在线视频| 日韩欧美福利视频| 国产性猛交xxxx免费看久久| 国产不卡av在线| 日韩在线观看免费高清完整版| 亚洲午夜av电影| 日韩av黄色在线观看| 热久久这里只有精品| 亚洲黄色在线看| 国产人妖伪娘一区91| 亚洲欧美另类人妖| 亚洲色无码播放| 亚洲国产成人精品久久久国产成人一区| 最近2019年日本中文免费字幕| 91久久久久久久一区二区| 国产成人精品一区二区在线| 狠狠躁夜夜躁人人躁婷婷91| 久久99视频免费| 少妇激情综合网| 日本视频久久久| 久久国产精品久久久| 欧美性少妇18aaaa视频| 91精品视频在线播放| 国产精品啪视频| 青草青草久热精品视频在线网站| 日本精品一区二区三区在线播放视频| 国产精品av电影| 欧美在线精品免播放器视频| 亚洲午夜性刺激影院| 亚洲精品国产综合区久久久久久久| 97免费视频在线播放| 亚洲国产欧美一区二区丝袜黑人| 在线色欧美三级视频| 激情亚洲一区二区三区四区| 亚洲视频日韩精品| 亚洲精品日韩激情在线电影| 91大神在线播放精品| 色视频www在线播放国产成人| 欧美午夜激情小视频| 国产精品久久久久av| 日韩免费av片在线观看| 精品国产鲁一鲁一区二区张丽| 欧美视频一二三| 成人综合国产精品| 色综合久久中文字幕综合网小说| 欧美自拍视频在线观看| 欧美精品性视频| 亚洲欧美制服中文字幕| 亚洲社区在线观看| 国产精品激情av电影在线观看| 最好看的2019的中文字幕视频| 精品成人久久av| 亚洲偷熟乱区亚洲香蕉av| 国产美女直播视频一区| 欧美一级淫片播放口| 2018中文字幕一区二区三区| 国产精品日韩专区| 精品日本美女福利在线观看| 欧美激情一区二区久久久| 91手机视频在线观看| 国产精品久久久久久久天堂| 超碰日本道色综合久久综合| 亚洲黄一区二区| 久久色在线播放| 国语自产偷拍精品视频偷| 欧美一级视频一区二区| 欧美剧在线观看| 亚洲r级在线观看| 国产小视频91| 日本不卡高字幕在线2019| 午夜精品久久久99热福利| 国产精品久久久久91| 欧美一级淫片videoshd| 国产成人精品一区二区三区| 亚洲国产精品国自产拍av秋霞| 亚洲精品ady| 日韩亚洲欧美中文在线| 国产99久久精品一区二区| 成人免费xxxxx在线观看| 亚洲欧洲在线免费| 亚洲一区二区在线播放| 欧美国产日本高清在线| 日韩在线视频网站| 一本大道亚洲视频| 欧美成人免费小视频| 欧美乱大交xxxxx另类电影| 91精品久久久久久久久中文字幕| 91香蕉国产在线观看| 91精品久久久久久久久久| 91高清免费视频| 久久九九热免费视频| 91精品国产91久久久久久最新| 中文字幕在线看视频国产欧美在线看完整| 欧美一区二区三区免费视| 欧美日韩国产成人高清视频| 国产精品白丝av嫩草影院| www.日韩.com| www.日本久久久久com.| 国产一区二区三区四区福利| 4438全国亚洲精品在线观看视频| 91久久中文字幕| 日韩视频在线观看免费| 亚洲综合成人婷婷小说| 青草青草久热精品视频在线网站| 国产精品青草久久久久福利99| 国产精品亚洲第一区| 国产日韩精品在线播放| 91亚洲午夜在线| 中文字幕亚洲一区在线观看| 精品久久久一区| 日韩欧美在线观看视频| 欧美电影在线观看高清| 中文综合在线观看| 奇米成人av国产一区二区三区| 色综合五月天导航| 久久露脸国产精品| 久久深夜福利免费观看| 这里只有精品久久| 欧美极品少妇xxxxⅹ免费视频| 蜜月aⅴ免费一区二区三区| 最近更新的2019中文字幕| 日韩中文字幕不卡视频| 97**国产露脸精品国产| 国产精品亚洲片夜色在线| 精品在线欧美视频| 亚洲美女久久久| 91久久在线视频| 亚洲成人精品久久久| 亚洲精品成人久久电影|