开发者

how to search sqlite database using regular expression in android?

开发者 https://www.devze.com 2023-04-01 20:58 出处:网络
I am trying to search a database using regular expression in sqlite. Here is my code: cursor = db.rawQuery(\"SELECT _id, employee FROM employees WHERE employee REGEXP ?\",

I am trying to search a database using regular expression in sqlite. Here is my code:

cursor = db.rawQuery("SELECT _id, employee FROM employees WHERE employee REGEXP ?", 
                    new String[]{"%" + prepareSearchText()  + "%"});
    adapter = new SimpleCursorAdapter(
            this,
            R.layout.search_row, 
            cursor, 
            new String[] {"_id", "employee "}, 
            new int[] {R.id.idField, R.id.nameField});
    setListAdapter(adapter);

However I am getting this error:

Caused by: android.database.sqlite.SQLiteExc开发者_Python百科eption: no such function: REGEXP.

I used the function REGEXP in MySQL before so I assumed it exists in sqlite, but apparently it is not.

What is the best way to perform regular expression when querying sqlite database in android?


In sqllite the "REGEXP" function is not included by default and you need to "roll your own".

However the "LIKE" operator should do what you want as long as your searches are reasonably simple.

the docs


As James suggested, use the LIKE operator, and then do a java search on the results using regular expressions

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号