greenDao插入数据无效(多表关联)

直接说我的案例吧,学生选课,一个学生有多个课,也就是student中有一个List<Course>。因为是多对多的关系,所以建立了第三张表JoinCourseToStudent。

     @Entity
public class Student {
    @Id(autoincrement = true)
    Long sid;
    String name;
    @ToMany
    @JoinEntity(
            entity = JoinCourseToStudent.class,
            sourceProperty = "sid",
            targetProperty = "cid"
    )
    private List<Course> courses;
    @ToMany(referencedJoinProperty = "sid")
    private List<Score> scores;


@Entity
public class Course {
    @Id(autoincrement = true)
    private Long id;
    private Long teacherId;
    private String name,college,place;
    @ToMany
    @JoinEntity(
            entity = JoinCourseToTime.class,
            sourceProperty = "cid",
            targetProperty = "tid"
    )
    private List<Time> times;
    @ToMany
    @JoinEntity(
            entity = JoinCourseToStudent.class,
            sourceProperty = "cid",
            targetProperty = "sid"
    )
    private List<Student> students;

@Entity
public class JoinCourseToStudent {
    @Id(autoincrement = true)
    private Long id;
    private Long cid;
    private Long sid;


每次选课的时候提取当前学生的已有课程List<Course>,一一比较当前课是否已选,未选的话则为joinCourseToStudent插入一条数据,与之对应的也就是student的List<Course>增加一条。

然而选完课A之后再次选发现没有提示“当前课程已选”,进一步发现List<Course>没有更新,没有新增的一条Course,退出应用重新加载后才更新。

原因是在多表关联中,比如本案例中一个学生有多个课程,插入数据后当前操作的list并不会更新,即使你重新通过学生获取这个list,也是没有更新的缓存版本,必须手动更新:

student.resetCourses();

每次进行数据后这样将操作的数据与数据库进行同步就可以了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用 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 操作实体类时,可以通过关联字段进行关联查询。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值