关于sqlite的特殊字符转义及通配符
2016-03-09 17:44
585 查看
原址:http://blog.csdn.net/ameyume/article/details/8007149
相关的其他地址:http://blog.csdn.net/forlong401/article/details/11749829
转】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 '\';
public static String sqliteEscape(String keyWord){
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(")", "/)");
return keyWord;
}
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/forlong401/article/details/11749829
转】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 '\';
public static String sqliteEscape(String keyWord){
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(")", "/)");
return keyWord;
}
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 的所有作者的姓氏。
相关文章推荐
- jedis调用redis之pool
- SQL分组统计:由一个表的两列作为轴
- zabbix监控mongodb
- Oracle学习笔记——1、基本的SQL语句
- Microsoft SQL Server 2005 Service fails to start
- percona-toolkit系列之介绍和安装(mysql复制工具)
- oracle备份imp命令大全
- ora-02064不支持分布式操作与Oracle自治事务
- PostgreSQL 三节点集群故障模拟及恢复
- jedis调用redis之分页
- 防止mysql注入
- mysql int转换成string时类型要用char
- Gneymotion无法启动和Oracle VM VirtualBox常见问题
- 踩坑事件:不能对基于文本的临时表使用sql insert语句
- 复制表数据Sql
- sqlplus中其他命令的使用timing,store,host。。
- 让VisualStudio Profiler捕捉执行的sql语句
- MariaDB通过命令行还原数据库
- mysql连接的问题
- mysql启动失败:不能创建pid文件