《SQL必知必會(huì)》筆記(MySQL實(shí)現(xiàn))---通配符的使用

本文主要講的是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é)果如下:

百分號(hào)通配符-1.png

可以看到系任,這條語(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é)果如下:

百分號(hào)通配符-2.png

這條語(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é)果如下:

下劃線通配符-1.png

這個(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é)果如下:

下劃線通配符-2.png

這個(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í)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市锡宋,隨后出現(xiàn)的幾起案子儡湾,更是在濱河造成了極大的恐慌,老刑警劉巖执俩,帶你破解...
    沈念sama閱讀 216,744評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件徐钠,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡役首,警方通過(guò)查閱死者的電腦和手機(jī)尝丐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)衡奥,“玉大人爹袁,你說(shuō)我怎么就攤上這事“蹋” “怎么了失息?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,105評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)乏屯。 經(jīng)常有香客問(wèn)我根时,道長(zhǎng),這世上最難降的妖魔是什么辰晕? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,242評(píng)論 1 292
  • 正文 為了忘掉前任蛤迎,我火速辦了婚禮,結(jié)果婚禮上含友,老公的妹妹穿的比我還像新娘替裆。我一直安慰自己,他們只是感情好窘问,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,269評(píng)論 6 389
  • 文/花漫 我一把揭開(kāi)白布辆童。 她就那樣靜靜地躺著,像睡著了一般惠赫。 火紅的嫁衣襯著肌膚如雪把鉴。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,215評(píng)論 1 299
  • 那天儿咱,我揣著相機(jī)與錄音庭砍,去河邊找鬼。 笑死混埠,一個(gè)胖子當(dāng)著我的面吹牛怠缸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播钳宪,決...
    沈念sama閱讀 40,096評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼揭北,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼扳炬!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起搔体,我...
    開(kāi)封第一講書(shū)人閱讀 38,939評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤恨樟,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后嫉柴,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體厌杜,經(jīng)...
    沈念sama閱讀 45,354評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,573評(píng)論 2 333
  • 正文 我和宋清朗相戀三年计螺,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瞧壮。...
    茶點(diǎn)故事閱讀 39,745評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡登馒,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出咆槽,到底是詐尸還是另有隱情陈轿,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評(píng)論 5 344
  • 正文 年R本政府宣布秦忿,位于F島的核電站麦射,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏灯谣。R本人自食惡果不足惜潜秋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,048評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望胎许。 院中可真熱鬧峻呛,春花似錦、人聲如沸辜窑。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,683評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)穆碎。三九已至牙勘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間所禀,已是汗流浹背方面。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,838評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留北秽,地道東北人葡幸。 一個(gè)月前我還...
    沈念sama閱讀 47,776評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像贺氓,于是被迫代替她去往敵國(guó)和親蔚叨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子床蜘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,652評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容