【整理】关于sqlite的特殊字符转义及通配符

前端之家收集整理的这篇文章主要介绍了【整理】关于sqlite的特殊字符转义及通配符前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

【转】1.sqlite中的转义符

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

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

需要注意的是,特殊字符并没有用反斜杠“\”表示转义符。
这句话是不正确的,至少在sqliteman中是可以使用'\'或'/'作为转义符的。
以下查询语句,都可以查询出相同的结果:
select _id,_data from images where _data like '%/"hello/"%' escape '/';
select _id,_data from images where _data like '%\"hello\"%' escape '\';


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


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 的所有作者的姓氏。


转自:http://blog.csdn.net/ameyume/article/details/8007149

猜你在找的Sqlite相关文章