GreenDao关系建表
关系
在greenDAO,实体涉及使用一对一或一对多的关系。例如,如果要模拟一个1:greenDAOñ关系,你将有一个一对一和一对多的关系。但是,请注意,一对一和一对多的关系不是相互连接,所以你必须同时更新。
//学生
@Entity
public class Student {
@Id
private Long id ;
private String name ;
private String number ;
private long PE_Id ;
@ToOne(joinProperty = "PE_Id")
private PEClazz peClazz;
}
//体育课
@Entity
public class PEClazz {
@Id
private Long id;
private int credit;
private String name;
}
建立一对一关系
@ToOne注释定义的关系向另一个实体(一个实体对象)
当 修改外键 时
Student student = studentDao.queryBuilder().where(StudentDao.Properties.Id.eq(1)).unique();
PEClazz peClazz = student.getPeClazz();
System.out.println("peClazz+id:"+peClazz.getId());
System.out.println("peClazz+name:"+peClazz.getName());
//修改体育课的ID
student.setPE_Id(2);
peClazz = student.getPeClazz();
System.out.println("peClazz+id:"+peClazz.getId());
System.out.println("peClazz+name:"+peClazz.getName());
运行结果(修改外键,外键对象受到改变)
peClazz+id:1
peClazz+name:篮球
peClazz+id:2
peClazz+name:足球
或者里(修改外键对象)
Student student = studentDao.queryBuilder().where(StudentDao.Properties.Id.eq(1)).unique();
PEClazz peClazz = student.getPeClazz();
System.out.println("peClazz+id:"+peClazz.getId());
//设置新的体育课
PEClazz newPeClazz = new PEClazz();
newPeClazz.setId(2L);
student.setPeClazz(newPeClazz);
System.out.println("student.PE_ID:"+student.getPE_Id());
运行结果 (修改外键对象,外键受到改变)
peClazz+id:1
student.PE_ID:2
注意
在一对一关系中,当要第一次加载时,使用的是懒加载。
后续调用将立即返回先前解析的对象。
如果外键属性(例如:PE_Id)受到了改变(或者外键对象受到改变(setPeClazz)),那么再次获取外键对象时(获取的外键)就会发生改变。
外键和外键对象具有关联.
建立一对多关系
//父亲类
@Entity
public class Father {
@Id
private Long id;
private String name;
@ToMany(referencedJoinProperty = "fatherID")
List<Son> sons ;
}
//儿子类
@Entity
public class Son {
@Id
private Long id;
private String name;
private long fatherID ;
}
@ToMany限定了关系到一组其他实体的(多个实体对象)。
referencedJoinProperty参数:指定指向该实体的ID目标实体的“外键”属性的名称。
先创建几个数据:
Son son1 = new Son();
son1.setName("儿子1");
Son son2 = new Son();
son2.setName("儿子2");
Son son3 = new Son();
son3.setName("儿子3");
Father father = new Father();
father.setName("父亲");
long fatherID = fatherDao.insertOrReplace(father);
son1.setFatherID(fatherID);
son2.setFatherID(fatherID);
son3.setFatherID(fatherID);
sonDao.insertOrReplace(son1);
sonDao.insertOrReplace(son2);
sonDao.insertOrReplace(son3);
更新操作注意
Father father = fatherDao.queryBuilder().where(FatherDao.Properties.Id.eq(1)).unique();
List<Son> sons = father.getSons();
for (Son son: sons) {
System.out.println("son:"+son.getName());
}
Son son = new Son();
son.setFatherID(father.getId());
son.setName("儿子4");
//插入
daoSession.insert(son);
for (Son newSon:
sons) {
System.out.println("newSon:"+newSon.getName());
}
//重新获取
List<Son> sons1 = father.getSons();
for (Son newSon1:
sons1) {
System.out.println("newSon1:"+newSon1.getName());
}
运行结果
son:儿子1
son:儿子2
son:儿子3
newSon:儿子1
newSon:儿子2
newSon:儿子3
newSon1:儿子1
newSon1:儿子2
newSon1:儿子3
注意
由上可知,虽然插入了一个新的,但是,getSons()获取的sons 并没有增加。
因为缓存在里面有列表对象,因此后续的关系get方法调用不查询数据库。
所以可以做以下操作。
//以下是getSons的代码
public List<Son> getSons() {
//为空,则重新查询
if (sons == null) {
final DaoSession daoSession = this.daoSession;
if (daoSession == null) {
throw new DaoException("Entity is detached from DAO context");
}
SonDao targetDao = daoSession.getSonDao();
List<Son> sonsNew = targetDao._queryFather_Sons(id);
synchronized (this) {
if(sons == null) {
sons = sonsNew;
}
}
}
//否则返回以前的缓存
return sons;
}
要增加新的关联实体,需要手工将它们添加到源实体的一对多列表
//插入
daoSession.insert(son);
//再插入以后,应该为列表手工添加son
//手工添加
sons.add(son);
for (Son newSon:
sons) {
System.out.println("newSon:"+newSon.getName());
}
//重新获取
List<Son> sons1 = father.getSons();
for (Son newSon1:
sons1) {
System.out.println("newSon1:"+newSon1.getName());
}
运行结果
son:儿子1
son:儿子2
son:儿子3
newSon:儿子1
newSon:儿子2
newSon:儿子3
newSon:儿子4
newSon1:儿子1
newSon1:儿子2
newSon1:儿子3
newSon1:儿子4
或者
//插入
daoSession.insert(son);
//再插入以后
/使用重置方法来清除缓存列表
father.resetSons();
for (Son newSon:
sons) {
System.out.println("newSon:"+newSon.getName());
}
//重新获取
List<Son> sons1 = father.getSons();
for (Son newSon1:
sons1) {
System.out.println("newSon1:"+newSon1.getName());
}
运行结果
son:儿子1
son:儿子2
son:儿子3
newSon:儿子1
newSon:儿子2
newSon:儿子3
newSon1:儿子1
newSon1:儿子2
newSon1:儿子3
newSon1:儿子4
由上可知
sons列表中没有添加上去,但是重新getSons()后,发现新插入的son已经加入了进去.
father.resetSons();由源码可知:
public synchronized void resetSons() {
sons = null;
}
sons为null了,所以当要getSons()时,因为son==null,所以会重新从数据库中重新查询数据。
当添加,更新或删除许多相关的实体可以使用重置方法来清除缓存列表。那么接下来get会重新查询相关实体:
GreenDao关系建表的更多相关文章
- Python3-sqlalchemy-orm 多对多关系建表、插入数据、查询数据
现在来设计一个能描述"图书"与"作者"的关系的表结构,需求是 一本书可以有好几个作者一起出版 一个作者可以写好几本书 此时你会发现,用之前学的外键好像没办法实现 ...
- ORM对象关系映射之GreenDAO建立多表关联
利用GreenDAO可以非常方便的建立多张表之间的关联 一对一关联 通常我们在操作数据库的时候,我们往往不是单独的对一张表进行操作,而是对这张表的操作会联动的影响另外一张表或者多张表,比如:现在有两张 ...
- (33)关于django中路由自带的admin + 建表关系的讲解
admin是django自带的后台管理,在初始的时候就默认配置好了 当输入ip地址的时候后面跟admin,就会登陆管理员的后台,这个是django自带的,可以快速管理数据表(增删改查) PS:ip地址 ...
- EF简易教程,从建表到表间关系
唐大兵博客 唐大兵的博客里记录了EF Code First从建表到表之间关系的详细内容. 汪杰的博客(EF里一对一.一对多.多对多关系的配置和级联删除) 汪杰的博客更简洁,但不够充实,读懂了唐大兵博客 ...
- Android ORM对象关系映射之GreenDAO建立多表关联
https://blog.csdn.net/u010687392/article/details/48496299 利用GreenDAO可以非常方便的建立多张表之间的关联 一对一关联 通常我们在操作数 ...
- Hibernate多对多关系映射(建表)
下边讲述Hibernate多对多关系映射. 多对多关系的表的结构为: 两个实体表,还包含一个关系表,关系表为复合主键,如果要使用Hibernate多对多关系映射,则关系表必须只包含两个字段,如果生成了 ...
- Oracle建表
1.oracle数据库中的多种数据结构: 1.表结构 存储数据 2.视图 一张表或多张表中数据的字节 3.sequence 主要用来生成主键值 4.index 提高检索性能 我们 ...
- 关于MySQL建表
规范一些常用字段. password:varchar name:varchar 时间存储全部存储时间戳,用bigint(20),拒绝使用 MySQL数据类型 mysql数据类型 含义 date 3字 ...
- Oracle 建表常用数据类型的详解
创建表时,必须为表的各个列指定数据类型.如果实际的数据与该列的数据类型不相匹配,则数据库会拒绝保存.如为学生指定出生日期为“1980-13-31”. 在Oracle中,常见的数据类型有: 字符串:字符 ...
随机推荐
- 使用jspatch进行热修复的实战总结
最近正式在线上项目中集成了jspatch进行热修复,这里做一个简单的总结. 工具篇: 首先,用xcode来编辑js非常困难,基本上没有缩进,完全需要手写:经过研究发现使用 Sublime text3 ...
- ubuntu 更改时区
更改/etc/timezone Asia/Chongqing sudo dpkg-reconfigure tzdata
- HTML初级入门内容
常用属性: Width=宽度 Height=高度 Size=大小 Color=颜色 Align=布局方向,值包括(top,bottom,left,right,center)上,下,左,右,中. Bor ...
- sys.stdout.write与sys.sterr.write(一)
目标: 1.使用sys.stdout.write输入0-9数字 2.使用sys.stderr.write输出0-9数字 3.使用两种方式输出0-9,显示0变化到9的过程 1.使用sys.stdout. ...
- Android 基于Android的手机邮件收发(JavaMail)之二( Welcome.java 和 ReceiveAndSend.java )
周末休息,这次我们继上次内容继续.上一篇内容我们讲述的是一些准备工作.下载两个javamail.jar和activation.jar文件,然后再BuildPath~ 言归正传,为了展示效果,在这里我申 ...
- 实时控制软件设计第一周作业-汽车ABS软件系统案例分析
汽车ABS软件系统案例分析 ABS 通过控制作用于车轮制动分泵上的制动管路压力,使汽车在紧急刹车时车轮不会抱死,这样就能使汽车在紧急制动时仍能保持较好的方向稳定性. ABS系统一般是在普通制动系统基础 ...
- magento目录结构说明,Magento文件夹结构说明,Magento folder structure
/app – 程序根目录 /app/etc – 全局配置文件目录 /app/code – 所有模块安装其模型和控制器的目录 /app/code/core – 核心代码或经过认证 ...
- Jmeter 简单用法
学习jmeter的部分用法,整理笔记: 老规矩上图: 一.录制脚本:Badboy或HTTP代理服务器: Badboy第三方软件,录制脚本后,可以直接导出为jmeter格式:再通过加载实现脚本: HTT ...
- axis2打包方式发布
参照http://gao-xianglong.iteye.com/blog/1744557这篇文章,注意的是打包services.xml的时候要将它的上级目录meta-inf一起打包,放到axis2\ ...
- Node.js 安装与配置
引言: JavaScript是一种运行在浏览器的脚本,它简单,轻巧,易于编辑,这种脚本通常用于浏览器的前端编程,但是一位开发者Ryan有一天发现这种前端式的脚本语言可以运行在服务器上的时候,一场席卷全 ...