MySQL必知必會八:用通配符進行過濾

8.1 LIKE操作符

通配符(wildcard):用來匹配值的一部分的特殊字符。
搜索模式(search pattern):由字面值、通配符或兩者組合構成的搜索條件

爲在搜索子句中使用通配符,必須使用LIKE操作符。 LIKE指示MySQL,後跟的搜索模式利用通配符匹配而不是直接相等匹配進行比較。

8.1.1 百分號( %)通配符

最常使用的通配符是百分號(%)。在搜索串中, %表示任何字符出現任意次數。例如,爲了找出所有以詞jet起頭的產品,可使用以下SELECT語句:

mysql> SELECT prod_id, prod_name FROM products WHERE prod_name LIKE 'jet%';
+---------+--------------+
| prod_id | prod_name    |
+---------+--------------+
| JP1000  | JetPack 1000 |
| JP2000  | JetPack 2000 |
+---------+--------------+
2 rows in set (0.00 sec)
  • 分析:此例子使用了搜索模式’jet%’。在執行這條子句時,將檢索任意以jet起頭的詞。 %告訴MySQL接受jet之後的任意字符,不管它有多少字符。

通配符可在搜索模式中任意位置使用,並且可以使用多個通配符。下面的例子使用兩個通配符,它們位於模式的兩端:

mysql> SELECT prod_id, prod_name FROM products WHERE prod_name LIKE '%anvil%';
+---------+--------------+
| prod_id | prod_name    |
+---------+--------------+
| ANV01   | .5 ton anvil |
| ANV02   | 1 ton anvil  |
| ANV03   | 2 ton anvil  |
+---------+--------------+
  • 分析:搜索模式’%anvil%'表示匹配任何位置包含文本anvil的值,而不論它之前或之後出現什麼字符。

通配符也可以出現在搜索模式的中間,雖然這樣做不太有用。下面的例子找出以s起頭以e結尾的所有產品:

mysql> SELECT prod_name FROM products WHERE prod_name LIKE 's%e';
  • 分析:重要的是要注意到,除了一個或多個字符外, %還能匹配0個字符。 %代表搜索模式中給定位置的0個、 1個或多個字符。

注意尾空格 尾空格可能會干擾通配符匹配。例如,在保存詞anvil 時 , 如果它後面有一個或多個空格 , 則子句WHERE prod_name LIKE '%anvil'將不會匹配它們,因爲在最後的l後有多餘的字符。解決這個問題的一個簡單的辦法是在搜索模式最後附加一個%。一個更好的辦法是使用函數去掉首尾空格。
注意NULL:雖然似乎%通配符可以匹配任何東西,但有一個例外,即NULL。即使是WHERE prod_name LIKE '%'也不能匹配用值NULL作爲產品名的行。

8.1.2 下劃線( _)通配符

另一個有用的通配符是下劃線(_)。下劃線的用途與%一樣,但下劃線只匹配單個字符而不是多個字符。

mysql> SELECT prod_id, prod_name FROM products WHERE prod_name LIKE '_ ton anvil';
+---------+-------------+
| prod_id | prod_name   |
+---------+-------------+
| ANV02   | 1 ton anvil |
| ANV03   | 2 ton anvil |
+---------+-------------+
  • 分析:與%能匹配0個字符不一樣, _總是匹配一個字符,不能多也不能少。

8.2 使用通配符的技巧

正如所見, MySQL的通配符很有用。但這種功能是有代價的:通配符搜索的處理一般要比前面討論的其他搜索所花時間更長。這裏給出一些使用通配符要記住的技巧。

  • 不要過度使用通配符。如果其他操作符能達到相同的目的,應該使用其他操作符。
  • 在確實需要使用通配符時,除非絕對有必要,否則不要把它們用在搜索模式的開始處。把通配符置於搜索模式的開始處,搜索起來是最慢的。
  • 仔細注意通配符的位置。如果放錯地方,可能不會返回想要的數據。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章