greenDao多表关联To-Many踩过的坑

在greenDao中使用一对多关联关系表时,如一个用户user对应多个订单orders,user中的getOrders(),在实体orders更新后,user应该调用reset方法,才能获得更新后的orders列表这是因为orders在第一次加载时,会缓存在一个list表中,以后查询时,直接从表中取。增加新的order实体后,getOrders()获得的仍是原来缓存的List表,并没有自动更新,因此需要调用reset方法,再getOrders()获得更新后的list表

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
下面是一个使用 GreenDAO 实现多表关联的示例: 假设有两个实体类 User 和 Order,一个用户可以有多个订单,一个订单只属于一个用户,因此可以使用一对多的关系进行关联。 首先,定义 User 实体类: ```java @Entity public class User { @Id(autoincrement = true) private Long id; private String name; @ToMany(referencedJoinProperty = "userId") private List<Order> orders; // 省略 getter 和 setter 方法 } ``` 其中,使用 `@ToMany` 注解表示一个用户可以有多个订单,`referencedJoinProperty` 参数指定了 Order 实体类中与 User 实体类关联的字段。 接着,定义 Order 实体类: ```java @Entity public class Order { @Id(autoincrement = true) private Long id; private String orderName; private Long userId; @ToOne(joinProperty = "userId") private User user; // 省略 getter 和 setter 方法 } ``` 其中,使用 `@ToOne` 注解表示一个订单只属于一个用户,`joinProperty` 参数指定了 Order 实体类中与 User 实体类关联的字段。 然后,创建 GreenDAO 的生成代码(可通过 Android Studio 中的 Gradle 插件自动生成)。 最后,就可以通过 GreenDAO 提供的 API 对 User 和 Order 实体进行操作,例如: ```java // 新增一个用户和一个订单 User user = new User(); user.setName("张三"); userDao.insert(user); Order order = new Order(); order.setOrderName("订单1"); order.setUserId(user.getId()); orderDao.insert(order); // 查询一个用户及其所有订单 User user = userDao.queryBuilder() .where(UserDao.Properties.Id.eq(userId)) .build() .unique(); List<Order> orders = user.getOrders(); ``` 以上示例演示了如何使用 GreenDAO 实现多表关联。需要注意的是,在定义实体类时,需要使用 GreenDAO 提供的注解进行标注,并且需要在实体类中定义与关联实体类的关联字段。在使用 API 操作实体类时,可以通过关联字段进行关联查询。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值