mysql模式匹配和正则表达式_MySQL
正则表达式
SQL模式匹配
_ 下划线匹配任何单个字符
% 匹配任意数码字符
正则表达式的匹配
使用REGEXP和NOT REGEXP操作符
‘.’匹配任何单个的字符。
字符类“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的范围,使用一个“-”。“[a-z]”匹配任何字母,而“[0-9]”匹配任何数字。
“ * ”匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的“x”字符,“[0-9]*”匹配任何数量的数字,而“.*”匹配任何数量的任何字符。
为了找出以“b”开头的名字,使用“^”匹配名字的开始:
mysql> SELECT * FROM pet WHERE name REGEXP '^b';
SELECT * FROM `student` WHERE `username` REGEXP '1$'
为了找出包含一个“w”的名字,使用以下查询:
mysql> SELECT * FROM pet WHERE name REGEXP 'w';
你也可以使用“{n}”“重复n次”操作符重写前面的查询:
mysql> SELECT * FROM pet WHERE name REGEXP '^.{5}$';
对于REGEXP操作符,正则表达式可以使用任何下述特殊字符和结构:
· ^
匹配字符串的开始部分。
mysql> <strong>SELECT 'fo/nfo' REGEXP '^fo$';</strong> -> 0
mysql> <strong>SELECT 'fofo' REGEXP '^fo';</strong> -> 1
· $
匹配字符串的结束部分。
mysql> <strong>SELECT 'fo/no' REGEXP '^fo/no$';</strong> -> 1
mysql> <strong>SELECT 'fo/no' REGEXP '^fo$';</strong> -> 0
· .
匹配任何字符(包括回车和新行)。
mysql> <strong>SELECT 'fofo' REGEXP '^f.*$';</strong> -> 1
mysql> <strong>SELECT 'fo/r/nfo' REGEXP '^f.*$';</strong> -> 1
· a*
匹配0或多个a字符的任何序列。
mysql> <strong>SELECT 'Ban' REGEXP '^Ba*n';</strong> -> 1
mysql> <strong>SELECT 'Baaan' REGEXP '^Ba*n';</strong> -> 1
mysql> <strong>SELECT 'Bn' REGEXP '^Ba*n';</strong> -> 1
· a+
匹配1个或多个a字符的任何序列。
mysql> <strong>SELECT 'Ban' REGEXP '^Ba+n';</strong> -> 1
mysql> <strong>SELECT 'Bn' REGEXP '^Ba+n';</strong> -> 0
· a?
匹配0个或1个a字符。
mysql> <strong>SELECT 'Bn' REGEXP '^Ba?n';</strong> -> 1
mysql> <strong>SELECT 'Ban' REGEXP '^Ba?n';</strong> -> 1
mysql> <strong>SELECT 'Baan' REGEXP '^Ba?n';</strong> -> 0
· de|abc
匹配序列de或abc。
mysql> <strong>SELECT 'pi' REGEXP 'pi|apa';</strong> -> 1
mysql> <strong>SELECT 'axe' REGEXP 'pi|apa';</strong> -> 0
mysql> <strong>SELECT 'apa' REGEXP 'pi|apa';</strong> -> 1
mysql> <strong>SELECT 'apa' REGEXP '^(pi|apa)$';</strong> -> 1
mysql> <strong>SELECT 'pi' REGEXP '^(pi|apa)$';</strong> -> 1
mysql> <strong>SELECT 'pix' REGEXP '^(pi|apa)$';</strong> -> 0
· (abc)*
匹配序列abc的0个或多个实例。
mysql> <strong>SELECT 'pi' REGEXP '^(pi)*$';</strong> -> 1
mysql> <strong>SELECT 'pip' REGEXP '^(pi)*$';</strong> -> 0
mysql> <strong>SELECT 'pipi' REGEXP '^(pi)*$';</strong> -> 1
· {1}, {2,3}
{n}或{m,n}符号提供了编写正则表达式的更通用方式,能够匹配模式的很多前述原子(或“部分”)。m和n均为整数。
o a*
可被写入为a{0,}。
o a+
可被写入为a{1,}。
o a?
可被写入为a{0,1}。
更准确地讲,a{n}与a的n个实例准确匹配。a{n,}匹配a的n个或更多实例。a{m,n}匹配a的m~n个实例,包含m和n。
m和n必须位于0~RE_DUP_MAX(默认为255)的范围内,包含0和RE_DUP_MAX。如果同时给定了m和n,m必须小于或等于n。
mysql> <strong>SELECT 'abcde' REGEXP 'a[bcd]{2}e';</strong> -> 0
mysql> <strong>SELECT 'abcde' REGEXP 'a[bcd]{3}e';</strong> -> 1
mysql> <strong>SELECT 'abcde' REGEXP 'a[bcd]{1,10}e';</strong> -> 1
· [a-dX], [^a-dX]
匹配任何是(或不是,如果使用^的话)a、b、c、d或X的字符。两个其他字符之间的“-”字符构成一个范围,与从第1个字符开始到第2个字符之间的所有字符匹配。例如,[0-9]匹配任何十进制数字 。要想包含文字字符“]”,它必须紧跟在开括号“[”之后。要想包含文字字符“-”,它必须首先或最后写入。对于[]对内未定义任何特殊含义的任何字符,仅与其本身匹配。
mysql> <strong>SELECT 'aXbc' REGEXP '[a-dXYZ]';</strong> -> 1
mysql> <strong>SELECT 'aXbc' REGEXP '^[a-dXYZ]$';</strong> -> 0
mysql> <strong>SELECT 'aXbc' REGEXP '^[a-dXYZ]+$';</strong> -> 1
mysql> <strong>SELECT 'aXbc' REGEXP '^[^a-dXYZ]+$';</strong> -> 0
mysql> <strong>SELECT 'gheis' REGEXP '^[^a-dXYZ]+$';</strong> -> 1
mysql> <strong>SELECT 'gheisa' REGEXP '^[^a-dXYZ]+$';</strong> -> 0
· [.characters.]
在括号表达式中(使用[和]),匹配用于校对元素的字符序列。字符为单个字符或诸如新行等字符名。在文件regexp/cname.h中,可找到字符名称的完整列表。
mysql> <strong>SELECT '~' REGEXP '[[.~.]]';</strong> -> 1
mysql> <strong>SELECT '~' REGEXP '[[.tilde.]]';</strong> -> 1
· [=character_class=]
在括号表达式中(使用[和]),[=character_class=]表示等同类。它与具有相同校对值的所有字符匹配,包括它本身,例如,如果o和(+)均是等同类的成员,那么[[=o=]]、[[=(+)=]]和[o(+)]是同义词。等同类不得用作范围的端点。
· [:character_class:]
在括号表达式中(使用[和]),[:character_class:]表示与术语类的所有字符匹配的字符类。标准的类名称是:
alnum |
文字数字字符 |
alpha |
文字字符 |
blank |
空白字符 |
cntrl |
控制字符 |
digit |
数字字符 |
graph |
图形字符 |
lower |
小写文字字符 |
图形或空格字符 |
|
punct |
标点字符 |
space |
空格、制表符、新行、和回车 |
upper |
大写文字字符 |
xdigit |
十六进制数字字符 |
它们代表在ctype(3)手册页面中定义的字符类。特定地区可能会提供其他类名。字符类不得用作范围的端点。
mysql> <strong>SELECT 'justalnums' REGEXP '[[:alnum:]]+';</strong> -> 1

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

全表掃描在MySQL中可能比使用索引更快,具體情況包括:1)數據量較小時;2)查詢返回大量數據時;3)索引列不具備高選擇性時;4)複雜查詢時。通過分析查詢計劃、優化索引、避免過度索引和定期維護表,可以在實際應用中做出最優選擇。

是的,可以在 Windows 7 上安裝 MySQL,雖然微軟已停止支持 Windows 7,但 MySQL 仍兼容它。不過,安裝過程中需要注意以下幾點:下載適用於 Windows 的 MySQL 安裝程序。選擇合適的 MySQL 版本(社區版或企業版)。安裝過程中選擇適當的安裝目錄和字符集。設置 root 用戶密碼,並妥善保管。連接數據庫進行測試。注意 Windows 7 上的兼容性問題和安全性問題,建議升級到受支持的操作系統。

InnoDB的全文搜索功能非常强大,能够显著提高数据库查询效率和处理大量文本数据的能力。1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

聚集索引和非聚集索引的區別在於:1.聚集索引將數據行存儲在索引結構中,適合按主鍵查詢和範圍查詢。 2.非聚集索引存儲索引鍵值和數據行的指針,適用於非主鍵列查詢。

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

MySQL 數據庫中,用戶和數據庫的關係通過權限和表定義。用戶擁有用戶名和密碼,用於訪問數據庫。權限通過 GRANT 命令授予,而表由 CREATE TABLE 命令創建。要建立用戶和數據庫之間的關係,需創建數據庫、創建用戶,然後授予權限。

MySQL 和 MariaDB 可以共存,但需要謹慎配置。關鍵在於為每個數據庫分配不同的端口號和數據目錄,並調整內存分配和緩存大小等參數。連接池、應用程序配置和版本差異也需要考慮,需要仔細測試和規劃以避免陷阱。在資源有限的情況下,同時運行兩個數據庫可能會導致性能問題。

MySQL支持四種索引類型:B-Tree、Hash、Full-text和Spatial。 1.B-Tree索引適用於等值查找、範圍查詢和排序。 2.Hash索引適用於等值查找,但不支持範圍查詢和排序。 3.Full-text索引用於全文搜索,適合處理大量文本數據。 4.Spatial索引用於地理空間數據查詢,適用於GIS應用。
