SQL——正则表达式
正則表達(dá)式的基本概念
正則表達(dá)式,又稱規(guī)則表達(dá)式,是計(jì)算機(jī)科學(xué)的一個(gè)概念。
(英語(yǔ):Regular Expression,在代碼中常簡(jiǎn)寫為regex、regexp或RE)
正則表達(dá)式是對(duì)字符串(包括普通字符(例如,a 到 z 之間的字母)和特殊字符(稱為“元字符”))操作的一種邏輯公式,
就是用事先定義好的一些特定字符、及這些特定字符的組合,組成一個(gè)“規(guī)則字符串”,這個(gè)“規(guī)則字符串”用來(lái)表達(dá)對(duì)字符串的一種過(guò)濾邏輯。
正則表達(dá)式是一種文本模式,該模式描述在搜索文本時(shí)要匹配的一個(gè)或多個(gè)字符串。
正則表達(dá)式通常被用來(lái)檢索、替換那些符合某個(gè)模式(規(guī)則)的文本。
許多程序設(shè)計(jì)語(yǔ)言都支持利用正則表達(dá)式進(jìn)行字符串操作。
顧名思義,就是一個(gè)有規(guī)則的表達(dá)式,按照這個(gè)規(guī)則的表達(dá)式去搜索匹配這個(gè)規(guī)則的字符串。
如AXXX;BXXX;這種規(guī)則表達(dá)式。
?
正則表達(dá)式在數(shù)據(jù)庫(kù)的應(yīng)用
MySQL可以通過(guò)?LIKE ...%?來(lái)進(jìn)行模糊匹配。
%、_、[a-d]與一些字符組合而成的匹配規(guī)則式就是正則表達(dá)式,這是在SQL里最常用的用法。
?
更復(fù)雜的正則表達(dá)式
MySQL 同樣也支持其他正則表達(dá)式的匹配, MySQL中使用 REGEXP 操作符來(lái)進(jìn)行正則表達(dá)式匹配。
如果您了解PHP或Perl,那么操作起來(lái)就非常簡(jiǎn)單,因?yàn)镸ySQL的正則表達(dá)式匹配與這些腳本的類似。
一般這種復(fù)雜的寫法不用,用%、_、[abc]這些匹配模式基本也夠用了。
下表中的正則模式可應(yīng)用于 REGEXP 操作符中。
| ^ | 匹配輸入字符串的開始位置。如果設(shè)置了 RegExp 對(duì)象的 Multiline 屬性,^ 也匹配 '\n' 或 '\r' 之后的位置。='a%' |
| $ | 匹配輸入字符串的結(jié)束位置。如果設(shè)置了RegExp 對(duì)象的 Multiline 屬性,$ 也匹配 '\n' 或 '\r' 之前的位置。='%a' |
| . | 匹配除 "\n" 之外的任何單個(gè)字符。要匹配包括 '\n' 在內(nèi)的任何字符,請(qǐng)使用像 '[.\n]' 的模式。 |
| [...] | 字符集合。匹配所包含的任意一個(gè)字符。例如, '[abc]' 可以匹配 "plain" 中的 'a'。只匹配單個(gè)字符,該字符在方括號(hào)內(nèi)即可。 |
| [^...] | 負(fù)值字符集合。匹配未包含的任意字符。例如, '[^abc]' 可以匹配 "plain" 中的'p'。^是否定意思的脫字號(hào)。只匹配單個(gè)字符,該字符在方括號(hào)內(nèi)即可。 |
| p1|p2|p3 | 匹配 p1 或 p2 或 p3。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 則匹配 "zood" 或 "food"。 |
| * | 匹配前面的子表達(dá)式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等價(jià)于{0,}。 |
| + | 匹配前面的子表達(dá)式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等價(jià)于 {1,}。 |
| {n} | n 是一個(gè)非負(fù)整數(shù)。匹配確定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的兩個(gè) o。 ='%oo%',當(dāng)然也會(huì)匹配到fooo,因?yàn)橐卜?oo%。 |
| {n,m} | m 和 n 均為非負(fù)整數(shù),其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,o{2,5},匹配2到5個(gè)o。也沒(méi)有限制前后是否還可以再出現(xiàn)o,如果大于5也是可以匹配到的。因?yàn)閒oooooooo也符合該表達(dá)式。 |
?
實(shí)例
了解以上的正則需求后,我們就可以根據(jù)自己的需求來(lái)編寫帶有正則表達(dá)式的SQL語(yǔ)句。
以下我們將列出幾個(gè)小實(shí)例(表名:person_tbl )來(lái)加深我們的理解:
?
查找name字段中以'st'為開頭的所有數(shù)據(jù):
mysql> SELECT name FROM person_tbl WHERE name REGEXP '^st';等于SELECT name FROM person_tbl WHERE name like 'st%';
?
查找name字段中以'ok'為結(jié)尾的所有數(shù)據(jù):
mysql> SELECT name FROM person_tbl WHERE name REGEXP 'ok$';?
查找name字段中包含'mar'字符串的所有數(shù)據(jù):
mysql> SELECT name FROM person_tbl WHERE name REGEXP 'mar';?
查找name字段中以元音字符開頭或以'ok'字符串結(jié)尾的所有數(shù)據(jù):
mysql> SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';I為‘或’ = or
?
總結(jié)
以上是生活随笔為你收集整理的SQL——正则表达式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 项目过程管理(十七)结项
- 下一篇: springboot项目实现mqtt客户