本文主要講的是SQL中通配符的相關(guān)知識(shí)和使用方法窗悯。
之前介紹的所有的數(shù)據(jù)過(guò)濾操作都是針對(duì)已知值進(jìn)行?的区匣。但是,這種過(guò)濾方法不是任何時(shí)候都好用蒋院。比如當(dāng)需要搜索產(chǎn)品名中包含文本“Hello”的所有產(chǎn)品亏钩,用簡(jiǎn)單的比較操作符肯定沒(méi)法做到莲绰,這時(shí)就需要用到本文講的通配符。? 通配符 是用來(lái)匹配值的一部分的特殊字符姑丑,利用通配符蛤签,可以創(chuàng)建比較特定數(shù)據(jù)的搜索模式。關(guān)于搜索模式需要解釋一下栅哀, 搜索模式 指的是由字面值震肮、通配符或兩者組合構(gòu)成的?搜索條件。
通配符本身實(shí)際上是SQL的WHERE子句中有特殊含義的字符昌屉,SQL支持幾種通配符钙蒙。在句子中使用通配符的時(shí)候,需要配合LIKE操作符间驮。LIKE操作符指示DBMS躬厌,后跟的搜索模式是利用通配符匹配而不是簡(jiǎn)單的相等匹配進(jìn)行比較。
?嚴(yán)格意義上來(lái)說(shuō)竞帽,LIKE是 謂詞 而不是操作符扛施。這種說(shuō)法有點(diǎn)像我們學(xué)語(yǔ)文的時(shí)候分析句子的結(jié)構(gòu)里的”謂語(yǔ)“,所以屹篓,LIKE也不能單獨(dú)使用疙渣。還有一點(diǎn)需要注意的是,通配符搜索只能用于文本字段(字符串)堆巧,非文本字段不能使用通配符搜索妄荔。
MySQL支持百分號(hào)(%)和下劃線(_)這兩種通配符,下面來(lái)看看這兩種通配符的用法和區(qū)別谍肤。
百分號(hào)( % )通配符
在一般的使用中啦租,百分號(hào)( % )通配符是最常用的。在搜索串中荒揣,% 表示任何字符出現(xiàn)任意次數(shù)篷角。下面來(lái)看下如何使用,現(xiàn)在要找出所有以“Fish”起頭的產(chǎn)品:
SELECT prod_id, prod_name
FROM Products
WHERE prod_name LIKE 'Fish%';
結(jié)果如下:
可以看到系任,這條語(yǔ)句檢索了任意以"Fish"起頭的?產(chǎn)品名稱恳蹲,并且 % 匹配的是任意字符,不管有多少個(gè)俩滥。
根據(jù)DBMS的不同以及其配置嘉蕾,搜索可以是區(qū)分大小寫(xiě)的,如果是區(qū)分大小寫(xiě)的話霜旧,上面的查詢語(yǔ)句就不會(huì)返回值了荆针。MySQL是不區(qū)分大小寫(xiě)的。
通配符可以在搜索模式?中的任意位置使用,并且可以使用多個(gè)通配符航背。下面的例子來(lái)看一下使用兩個(gè)通配符的情況:
SELECT prod_id, prod_name
FROM Products
WHERE prod_name LIKE '%bean bag%';
結(jié)果如下:
這條語(yǔ)句會(huì)搜索任何位置上包含文本'bean bag'的值,不論它之前或者之后出現(xiàn)什么字符棱貌。
在日常的使用中玖媚,通過(guò)通配符來(lái)匹配Email地址是一個(gè)非常有效的方法,比如 WHERE email LIKE 'a%@example.com'
婚脱。
需要特別注意的是今魔,% 不僅可以匹配1個(gè)或者多個(gè)字符,還可以匹配0個(gè)字符障贸。還有一點(diǎn)就是错森,% 號(hào)無(wú)法匹配 NULL,就像之前說(shuō)過(guò)的一樣篮洁,DBMS不知道NULL將會(huì)代表什么涩维。
下劃線( _ )通配符
另一個(gè)需要介紹的是下劃線 _ 通配符。_ 的用法和 % 一樣?袁波,區(qū)別在于它只匹配單個(gè)字符瓦阐。
?先看下面這個(gè)例子:
SELECT prod_id, prod_name
FROM Products
WHERE prod_name, LIKE '__ inch teddy bear';
結(jié)果如下:
這個(gè)SQL語(yǔ)句檢索出了開(kāi)頭?是兩個(gè)字符的prod_name,?需要注意的地方就是需要匹配多少個(gè)字符就用多少個(gè)下劃線篷牌∷可以使用 % 通配符對(duì)照一下效果:
SELECT prod_id, prod_name
FROM Products
WHERE prod_name LIKE '% inch teddy bear';
結(jié)果如下:
這個(gè)結(jié)果可以充分的說(shuō)明? _ 和 % 的區(qū)別。
以上簡(jiǎn)單的介紹了一下這兩種通配符的用法和區(qū)別枷颊。
SQL的通配符使用起來(lái)很方便戳杀,功能也很強(qiáng)大,但是代價(jià)就是通配符搜索一般來(lái)說(shuō)會(huì)比之前介紹過(guò)的搜索耗費(fèi)更長(zhǎng)的時(shí)間夭苗。所以有一些通配符的使用技巧需要了解:
- 不要刻意的使用通配符信卡。如果其他操作符能達(dá)到相同目的,應(yīng)該使用其它操作符听诸。
- 當(dāng)必須使用通配符時(shí)坐求,盡量不要把它們放在搜索模式開(kāi)始的地方,因?yàn)榘淹ㄅ浞旁陂_(kāi)始的地方晌梨,搜索的效率是最慢的桥嗤。
- 最后需要注意的,也是最重要的仔蝌,就是一定要注意通配符的位置和數(shù)量泛领,因?yàn)橐坏┏隽耸裁磫?wèn)題,返回的結(jié)果可能和預(yù)期會(huì)有很大的出入敛惊。
以上就是本文的所有內(nèi)容渊鞋,下一篇文章將會(huì)介紹SQL中有關(guān)計(jì)算字段的知識(shí)。