關於sqlite的特殊字元轉義及萬用字元

來源:互聯網
上載者:User

1.sqlikte中的轉義符

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

    sqlite3資料庫在搜尋的時候,一些特殊的字元需要進行轉義, 具體的轉義如下: 
     /   ->    //
     '   ->    ''
     [   ->    /[
     ]   ->    /]
     %   ->    /%
     &   ->    /&
     _   ->    /_
     (   ->    /(
     )   ->    /)需要注意的是,特殊字元並沒有用反斜線“\”表示轉義符。

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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.