Android Sqlite数据库查询操作使用 '%?%' 的问题

Sqlite数据库查询操作使用 '%?%' 的问题,


public static final String QUERY_DREAM_BY_CONDITION = "select * from Journal where description like ’%?%‘ ";

Cursor cursor = db.rawQuery(ConstantUtil.QUERY_DREAM_BY_CONDITION, new String[]{condition}); // condition为查询条件


查询时会出错,log如下:

02-15 16:41:34.633: E/AndroidRuntime(10789): Uncaught handler: thread main exiting due to uncaught exception
02-15 16:41:34.803: E/AndroidRuntime(10789): android.database.sqlite.SQLiteException: bind or column index out of range: handle 0x4dbad8


具体原因好像是编码的问题:

参考资料:

http://www.eoeandroid.com/forum.php?mod=viewthread&tid=2172

http://www.eoeandroid.com/thread-27411-1-1.html


解决办法,用两个 %%,且不能用在sql语句中 (select * from Journal where description like ’%%?%%‘ 这也是不行的)


public static final String QUERY_DREAM_BY_CONDITION = "select * from Journal where description like ?";

Cursor cursor = db.rawQuery(ConstantUtil.QUERY_DREAM_BY_CONDITION, new String[]{"%%"+condition+"%%"});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值