在SQl like語句中,比如
SELECT * FROM user WHERE username LIKE '%luchi%'
SELECT * FROM user WHERE username LIKE '_luchi_',
但當like 所要查詢的字段中含有 % ,我們如何去查:
這個時候就需要指明 字段中的那個'%‘ 不作為通配符;
這里就需要用到 ESCAPE 轉義
測試:
這里我們使用這張表
轉義前:
SELECT * FROM user WHERE username LIKE '%%%';
這里會發(fā)現(xiàn)三個%號都被當做通配符了;
轉義后:
SELECT * FROM user WHERE username LIKE '%1%%' ESCAPE '1';
查詢成功
注:
- ESCAPE 后面跟著一個字符,里面寫著什么,什么就是轉義符;
- 然后就像 C語言中轉義字符一樣 例如 ‘\n','\t', 把這個字符寫在你需要轉義的那個%號前就可以了;
技巧與建議:
MySQL的通配符很有用。但這種功能是有代價的:通配符搜索的處理一般要比前面討論的其他搜索所花時間更長。這里給出一些使用通配符要記住的技巧。
- 不要過度使用通配符。如果其他操作符能達到相同的目的,應該 使用其他操作符。
- 在確實需要使用通配符時,除非絕對有必要,否則不要把它們用 在搜索模式的開始處。把通配符置于搜索模式的開始處,搜索起 來是最慢的。
- 仔細注意通配符的位置。如果放錯地方,可能不會返回想要的數(shù).
到此這篇關于詳解MySQL like如何查詢包含'%'的字段(ESCAPE用法)的文章就介紹到這了,更多相關MySQL like查詢%內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- MySQL中ESCAPE關鍵字的用法詳解
- mysql_escape_string()函數(shù)用法分析
- MySql escape的使用案例詳解