通配符在数据库查询语言中的使用

181 阅读2分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第31天,点击查看活动详情

用通配符进行过滤

LIKE操作符

LIKE指示MySQL后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较

%百分号通配符

%表示任何字符出现任意次数。、

例:为了找出以词jet起头的产品:

SELECT prod_id,prod_name
FROM products
WHERE prod_name LIKE 'jet%';

xn_2022-08-25_08-52-45

例:通配符可以在搜索模式的任意位置使用,并且可以使用多个通配符。

SELECT prod_id,prod_name
FROM products
WHERE prod_name LIKE '%anvil%';

xn_2022-08-25_08-56-52

🏳️‍🌈需要注意的是,%是可以匹配0个字符的。%代表搜索模式中给定位置的0个,1个,或多个字符。

🉐还需要注意的一点是,尾部空格是会干扰通配符的匹配的。如果在保存anvil时尾部有几个空格,‘%anvil’就没有办法匹配成功的。解决方法就是你在末尾也加上一个%。或者更好的方法是使用函数。

🏢虽然似乎%可以匹配任何东西,但是有一个例外,那就是NULL。即使是WHERE prod_name LIKE '%'也不能匹配用值为NULL的产品名。

_下划线通配符

下划线只匹配单个字符。

SELECT prod_id ,prod_name 
FROM products
WHERE prod_name LIKE '_ ton anvil';

xn_2022-08-25_09-06-27

📧和%不一样,下划线只能匹配一个字符,不能多也不能少。

使用通配符的技巧

  • 不要过度使用通配符,如果其他操作符能达到同样的目的,应该使用其他的操作符。
  • 在确实需要使用统配符的时候,尽量不要把他们用到搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。
  • 仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据。