mysql的like模式
模式匹配,使用SQL簡單正規表達式比較。返回1 (TRUE) 或 0 (FALSE)。 若 expr 或 pat 中任何一個為 NULL,則結果為 NULL。
模式不需要為文字字符串。例如,可以被指定為一個字符串表達式或表列。
在模式中可以同LIKE一起使用以下兩種通配符:
字符
說明
%
匹配任何數目的字符,甚至包括零字符
_
只能匹配一種字符
mysql> SELECT 'David!' LIKE 'David_';
-> 1
mysql> SELECT 'David!' LIKE '%D%v%';
-> 1
若要對通配符的文字實例進行檢驗, 可將轉義字符放在該字符前面。如果沒有指定 ESCAPE字符, 則假設為‘’。
字符串
說明
%
匹配一個 ‘%’字符
_
匹配一個 ‘_’ 字符
mysql> SELECT 'David!' LIKE 'David_';
-> 0
mysql> SELECT 'David_' LIKE 'David_';
-> 1
要指定一個不同的轉義字符,可使用ESCAPE語句:
mysql> SELECT 'David_' LIKE 'David|_' ESCAPE '|';
-> 1
轉義序列可以為空,也可以是一個字符的長度。 從 MySQL 5.1.2開始, 如若 NO_BACKSLASH_ESCAPES SQL模式被激活, 則該序列不能為空。
以下兩個語句舉例說明了字符串比較不區分大小寫,除非其中一個操作數為二進制字符串:
mysql> SELECT 'abc' LIKE 'ABC';
-> 1
mysql> SELECT 'abc' LIKE BINARY 'ABC';
-> 0
在MySQL中, LIKE 允許出現在數字表達式中。 (這是標準SQL LIKE 的延伸)。
mysql> SELECT 10 LIKE '1%';
-> 1
注釋: 由于 MySQL在字符串中使用 C轉義語法(例如, 用‘n’代表一個換行字符),在LIKE字符串中,必須將用到的‘’雙寫。例如, 若要查找 ‘n’, 必須將其寫成 ‘n’。而若要查找 ‘’, 則必須將其寫成 it as ‘’原因是反斜線符號會被語法分析程序剝離一次,在進行模式匹配時,又會被剝離一次,最后會剩下一個反斜線符號接受匹配。
文章來源:http://apps.hi.baidu.com/share/detail/6526024
相關文章:
1. MySQL中InnoDB和MyISAM類型的差別2. mysql like語句問題3. Mysql入門系列:需要避免的MYSQL客戶機程序設計錯誤4. MYSQL(電話號碼,身份證)數據脫敏的實現5. Mysql入門系列:MYSQL服務器內部安全性-安全數據目錄訪問6. Mysql故障排除:Starting MySQL. ERROR! Manager of pid-file quit without updating file7. MySQL之常用的MySQL優化工具解讀8. MySQL Innodb 存儲結構 和 存儲Null值 用法詳解9. Windows下在DOS用mysql命令行導入.sql文件10. Windwos下MySQL 64位壓縮包的安裝方法學習記錄
