加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 19:29:59 所属栏目:百科 来源:网络整理
导读:【转】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
  1. publicstaticStringsqliteEscape(StringkeyWord){
  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. returnkeyWord;
  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 的所有作者的姓氏。


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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读