微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

android – 为什么GreenDAO不完全支持LIKE运算符?

GreenDAO只支持LIKE运算符的一个位置.它就像 ?”

我想用各种这样的运算符来获取记录.例如,“LIKE%?”,“LIKE?%”和“LIKE%?%”.但GreenDAO不支持它.

我也使用了queryRaw()和queryRawCreate(),遗憾的是它也没有用.
例如:

libDocSeriesDao.queryRawCreate(
” Where T.Title Like ‘%?%’ Or T.ViewTitle Like ‘%?%'”,aKeyword,
aKeyword).listLazy();

任何帮助将不胜感激.

解决方法

使用’?’时,’%’字符不能是查询字符串的一部分字符.绑定参数时,可以使用%的任意组合.

以下是如何使用LIKE查询的示例(取自greenDA的https://github.com/greenrobot/greenDAO/commit/788313904fa58a0c8628f6b2e016a4a385f344c6单位测试):

Query<TestEntity> query = dao.queryBuilder().where(Properties.SimpleString.like("%robot")).build();
TestEntity entity2 = query.uniqueOrThrow();
assertEquals(entity.getId(),entity2.getId());

query.setParameter(0,"green%");
entity2 = query.uniqueOrThrow();
assertEquals(entity.getId(),"%enrob%");
entity2 = query.uniqueOrThrow();
assertEquals(entity.getId(),entity2.getId());

相同的原则对原始查询有效.对于您的示例,您应该这样做:

libDocSeriesDao.queryRawCreate(" Where T.Title Like ? Or T.ViewTitle Like ?",aKeyword).listLazy();

此外,aKeyword必须具有%字符.

原文地址:https://www.jb51.cc/android/313857.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐