使用greenDAO遇到的问题

前一阵花时间学习了一下greenDAO的使用,这两天已经把项目中之前使用的sqlite数据库操作改用greenDAO,但是在改动的过程中还是出了一些问题,问题主要集中在主键上,下面整理了一下在改动过程中遇到的问题。

  • 调用AbstractDAO中update()时抛出RuntimeException

Cannot update entity without key - was it inserted before?

  • 抛出该异常的原因:在调用update()时传入的主键为 null
  • 该问题的应用环境:表中满足某条件的记录不重复,有则改之,无则’加冕’。
  • 解决问题的方法:查询表中满足条件的记录,取其id赋值给新记录。

部分代码块

  • 数据操作封装
public void cache(Cache cache) {
    String address = cache.getAccessAddress();
    QueryBuilder<Cache> builder = mCacheManager.queryBuilder().
    where(Properties.AccessAddress.eq(address));

    List<Cache> list = builder.list();
    if (null == list || list.isEmpty()) {
        // 未缓存
        mCacheManager.insert(cache);
    } else {
        // 新记录的id传进来为null
        Cache entity = list.get(0);
        cache.setId(entity.getId());
        mCacheManager.update(cache);
    }
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值