LitePal数据库 boolean 条件查询

LitePal版本:
implementation ‘org.litepal.guolindev:core:3.2.3’

首先是抄作业的时候理解错了,无意间发现可以把key和value直接拼接成一个字符串:
LitePal.where(“type = 1 and enable = true”).find(Task.class);
其中 type 是 int 类型,enable 是 boolean 类型。

当我把作业抄“正确”的时候,
LitePal.where(“type = ? and enable = ?”, “1”, “true”).find(Task.class);
却查询不到数据,于是查找原因。

据说数据库里的 boolean 是用 0 和 1 表示的,又因为 where() 只能传入字符串,所以 true 是 “1”,false 是 “0”。
至于上面拼接的字符串为什么可以直接使用 true,没有深究,不得而知。
当然也可以写成
LitePal.where(“type = 1 and enable = 1”).find(Task.class);

其他常见方法:
1. and 条件查询
LitePal.where(“type = ? and enable = ?”, String.valueOf(1), “1”).find(Task.class);
如果传入 “true”、String.valueOf(true) 或者 Boolean.toString(false),都是查询不到数据的

2. or 条件查询
LitePal.where(“type = ? or enable = ?”, String.valueOf(1), “1”).find(Task.class);
如果 enable 传入 “true”,仅 type 有效,enable 不起作用

3. 单条件查询
LitePal.where(“enable = ?”, “1”).find(Task.class);

4. like 可以替换 =,暂时没有发现区别,不一一举例
LitePal.where(“type like 1 and enable like true”).find(Task.class);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值