当前位置:   article > 正文

关于sqlite的特殊字符转义及通配符_sqlite replace 特殊字符

sqlite replace 特殊字符

原贴地址:http://blog.csdn.net/ameyume/article/details/8007149


1.sqlikte中的转义符

SELECT * FROM table WHERE number LIKE  '%/%%' escape '/'

        sqlite3数据库在搜索的时候,一些特殊的字符需要进行转义,  具体的转义如下: 
              ->        //
           ->    ''
              ->        /[
              ->        /]
              ->        /%
              ->        /&
              ->        /_
              ->        /(
              ->        /)

需要注意的是,特殊字符并没有用反斜杠“\”表示转义符。

[java]  view plain copy
  1. public static String sqliteEscape(String keyWord){  
  2.     keyWord = keyWord.replace("/""//");  
  3.     keyWord = keyWord.replace("'""''");  
  4.     keyWord = keyWord.replace("[""/[");  
  5.     keyWord = keyWord.replace("]""/]");  
  6.     keyWord = keyWord.replace("%""/%");  
  7.     keyWord = keyWord.replace("&","/&");  
  8.     keyWord = keyWord.replace("_""/_");  
  9.     keyWord = keyWord.replace("(""/(");  
  10.     keyWord = keyWord.replace(")""/)");  
  11.     return keyWord;  
  12. }  


2.SQL语句中表示单个字符和任意多个字符的通配符

%
包含零个或多个字符的任意字符串。
WHERE title LIKE '%computer%' 将查找在书名中任意位置包含单词 "computer" 的所有书名。

_(下划线)
任何单个字符。
WHERE au_fname LIKE '_ean' 将查找以 ean 结尾的所有 4 个字母的名字(Dean、Sean 等)。

[ ]
指定范围 ([a-f]) 或集合 ([abcdef]) 中的任何单个字符。
WHERE au_lname LIKE '[C-P]arsen' 将查找以 arsen 结尾并且以介于 C 与 P 之间的任何单个字符开始的作者姓氏,例如 Carsen、Larsen、Karsen 等。

[^]
不属于指定范围 ([a-f]) 或集合 ([abcdef]) 的任何单个字符。
WHERE au_lname LIKE 'de[^l]%' 将查找以 de 开始并且其后的字母不为 l 的所有作者的姓氏。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/173882
推荐阅读
相关标签
  

闽ICP备14008679号