正则表达式
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

如何有效監控MySQL性能?使用mysqladmin、SHOWGLOBALSTATUS、PerconaMonitoringandManagement(PMM)和MySQLEnterpriseMonitor等工具。 1.使用mysqladmin查看連接數。 2.用SHOWGLOBALSTATUS查看查詢數。 3.PMM提供詳細性能數據和圖形化界面。 4.MySQLEnterpriseMonitor提供豐富的監控功能和報警機制。

MySQL和SQLServer的区别在于:1)MySQL是开源的,适用于Web和嵌入式系统,2)SQLServer是微软的商业产品,适用于企业级应用。两者在存储引擎、性能优化和应用场景上有显著差异,选择时需考虑项目规模和未来扩展性。

在需要高可用性、高級安全性和良好集成性的企業級應用場景下,應選擇SQLServer而不是MySQL。 1)SQLServer提供企業級功能,如高可用性和高級安全性。 2)它與微軟生態系統如VisualStudio和PowerBI緊密集成。 3)SQLServer在性能優化方面表現出色,支持內存優化表和列存儲索引。

mySqlManagesCharacterSetsetSandCollationsyutusututf-8asthEdeFault,允許ConfigurationAtdataBase,table和columnlevels,AndrequiringCarefullageLignmentToavoidMismatches.1)setDefeaultCharactersetTercharactersetEtCollacterSeteTandColletationForAdataBase.2)conformentcollecharactersettersetertersetcollatertersetcollationcollation

MySQL觸發器是與表相關聯的自動執行的存儲過程,用於在特定數據操作時執行一系列操作。 1)觸發器定義與作用:用於數據校驗、日誌記錄等。 2)工作原理:分為BEFORE和AFTER,支持行級觸發。 3)使用示例:可用於記錄薪資變更或更新庫存。 4)調試技巧:使用SHOWTRIGGERS和SHOWCREATETRIGGER命令。 5)性能優化:避免複雜操作,使用索引,管理事務。

在MySQL中創建和管理用戶賬戶的步驟如下:1.創建用戶:使用CREATEUSER'newuser'@'localhost'IDENTIFIEDBY'password';2.分配權限:使用GRANTSELECT,INSERT,UPDATEONmydatabase.TO'newuser'@'localhost';3.修正權限錯誤:使用REVOKEALLPRIVILEGESONmydatabase.FROM'newuser'@'localhost';然後重新分配權限;4.優化權限:使用SHOWGRA

MySQL適合快速開發和中小型應用,Oracle適合大型企業和高可用性需求。 1)MySQL開源、易用,適用於Web應用和中小型企業。 2)Oracle功能強大,適合大型企業和政府機構。 3)MySQL支持多種存儲引擎,Oracle提供豐富的企業級功能。

MySQL相比其他關係型數據庫的劣勢包括:1.性能問題:在處理大規模數據時可能遇到瓶頸,PostgreSQL在復雜查詢和大數據處理上表現更優。 2.擴展性:水平擴展能力不如GoogleSpanner和AmazonAurora。 3.功能限制:在高級功能上不如PostgreSQL和Oracle,某些功能需要更多自定義代碼和維護。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

WebStorm Mac版
好用的JavaScript開發工具