SQL中escape的主要用途

 SQL中escape的主要用途

1.使用   ESCAPE   关键字定义转义符。在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符。例如,要搜索在任意位置包含字符串   5%   的字符串,请使用:    
  WHERE   ColumnA   LIKE   '%5/%%'   ESCAPE   '/'  
2.ESCAPE   'escape_character'    
  允许在字符串中搜索通配符而不是将其作为通配符使用。escape_character   是放在通配符前表示此特殊用途的字符。  
   
  SELECT   *  
  FROM   finances  
  WHERE   description   LIKE   'gs_'   ESCAPE   'S'  
  GO  
   
  意思就是:  
  比如,我们要搜索一个字符串     "g_"     ,如果直接     like     "g_",那么   "_"的作用就是通配符,而不是字符,结果,我们会查到比如     "ga","gb","gc",而不是我们需要的   "g_".  
  用     LIKE   'gs_'   ESCAPE   'S'     's'表示特殊用法标志  
3.create   table   a   (name   varchar(10))  
  go  
  insert   into   a   select   '11%22'  
  union   all   select   '11%33'  
  union   all   select   '12%33'  
  go  
  select   *   from   a     WHERE   name   LIKE   '%/%33'   ESCAPE   '/'   --指定用'/'符号来说明跟在其后面的通配符字符为普能字符。(第二个%是字符不是通配符来的)  
  go  
  drop   table   a
结果为:  
  name                
  ----------    
  11%33  
  12%33  

 

SQL,LIKE操作符用于在搜索匹配模式。百分号(%)是LIKE操作符的通配符之一,用于表示任意字符的序列(包括零个字符)。当在LIKE操作符的模式使用百分号时,它表示可以匹配任意长度的字符序列。例如,如果你使用LIKE操作符的模式为'%apple%',它将匹配包含"apple"的任何字符串,无论"apple"出现在字符串的任何位置。\[1\] 另外,还有一个通配符是下划线(_),它与百分号类似,但限制在一个字符。当在LIKE操作符的模式使用下划线时,它表示可以匹配任意单个字符。例如,如果你使用LIKE操作符的模式为'_pple',它将匹配"apple"、"bpple"、"cpple"等字符串,但不匹配"aple"或"apple"。\[2\] 需要注意的是,如果你想在LIKE操作符的模式搜索包含百分号或下划线的实际字符,而不是作为通配符,你可以使用转义字符(通常是反斜杠)来转义它们。例如,如果你想搜索包含"%"的字符串,你可以使用LIKE操作符的模式为'abc\%'。这样,百分号将被视为普通字符而不是通配符。\[1\] 总结起来,百分号(%)在SQL的LIKE操作符用作通配符,表示匹配任意长度的字符序列。下划线(_)也是一个通配符,但限制在一个字符。如果你想在LIKE操作符的模式搜索包含百分号或下划线的实际字符,你可以使用转义字符来转义它们。\[1\]\[2\] #### 引用[.reference_title] - *1* [MySql的like语句的通配符:百分号、下划线和escape](https://blog.csdn.net/weixin_48000648/article/details/107181812)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [SQL谓词LIKE操作符及通配符百分号%,下划线_,括号[]](https://blog.csdn.net/qq_43511299/article/details/114093463)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值