包含特殊字符的 SQLite 查询

SQLite query that contains special characters

我必须构建 SQLite 数据库,在其中存储一些具有特殊字符的字符串,对于大多数情况,它都可以找到,除了这个

SELECT * FROM table1 WHERE use_id = 3B:02

它抛出这个错误

android.database.sqlite.SQLiteException: near ":02": syntax error (code 1):

这个“3B:02”是可变的,我该如何处理

这是我的查询

selectQuery = "SELECT * FROM " + DataBaseHelper.TABLE_COM + " WHERE "
                + DataBaseHelper.COLUMN_USER_ID + " = " + value;

SQL 中的字符串文字值需要在 'single quotes'.

但是,最好对文字使用 ? 占位符并绑定值,例如

Cursor c = db.rawQuery("SELECT * FROM " + DataBaseHelper.TABLE_COM + " WHERE "
            + DataBaseHelper.COLUMN_USER_ID + " = ?", new String[] { value });