【转】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 '\';



1. public static
2. "/", "//");
3. "'", "''");
4. "[", "/[");
5. "]", "/]");
6. "%", "/%");
7. "&","/&");
8. "_", "/_");
9. "(", "/(");
10. ")", "/)");
11. return
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 的所有作者的姓氏。