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

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

概述【转】1.sqlite中的转义符 SELECT * FROM table WHERE number LIKE  '%/%%' escape '/'         sqlite3数据库在搜索的时候,一些特殊的字符需要进行转义,  具体的转义如下:            /      ->        //          '   ->    ''           [      ->   

【转】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 copy publicstaticStringsqliteEscape(StringkeyWord){ keyWord=keyWord.replace("/","//"); keyWord=keyWord.replace("'","''"); keyWord=keyWord.replace("[","/["); keyWord=keyWord.replace("]","/]"); keyWord=keyWord.replace("%","/%"); keyWord=keyWord.replace("&","/&"); keyWord=keyWord.replace("_","/_"); keyWord=keyWord.replace("(","/("); keyWord=keyWord.replace(")","/)"); returnkeyWord; }

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的特殊字符转义及通配符全部内容,希望文章能够帮你解决【整理】关于sqlite的特殊字符转义及通配符所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1166554.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存