Android ORM对象关系映射之GreenDAO建立多表关联

https://blog.csdn.net/u010687392/article/details/48496299

利用GreenDAO可以非常方便的建立多张表之间的关联

一对一关联

通常我们在操作数据库的时候,我们往往不是单独的对一张表进行操作,而是对这张表的操作会联动的影响另外一张表或者多张表,比如:现在有两张表,一张是用户User表(有name、age、sex三个字段),一张是头像Picture表(有pictureId、pictureName、width、height四个字段)。假如用户表和头像表是一对一关系,一个用户只有一个头像,一个头像只能有一个用户,所以要建立这两张表之间的联系,这两张表肯定是需要关联的,这样就可以通过用户的信息得到它的头像信息。我们知道在数据库中,关联两张表(暂且不说多对多关系的)一般都是把一张表的主键作为另外一张表的外键来做的,所以在Android中也同样,如果我们要关联User表和Picture表,那么只需要把Picture表的主键(假如是pictureId)作为User表的外键即可,另外一个亦是如此,如: 
 
假设还是以上面的场景为例,则利用GreenDAO建立User表和Picture表一对一的关联可以这样建立:

//把User表的主键name作为Picture表的外键,把Picture的主键pictureId作为User表的外键,这样得到任何一个实体的信息都可以得到关联的另外一个实体的信息
        Property property =  user.addLongProperty("pictureId").getProperty();
        user.addToOne(picture,property);

        Property propertyName = picture.addStringProperty("name").getProperty();
        picture.addToOne(user,propertyName);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

在为Schema添加实体的时候,我们在相应的实体中添加另外一个表的主键即可:

        Schema schema = new Schema(1,"com.sunzxyong.greendao2");
        //User
        Entity user = schema.addEntity("User");
        user.addStringProperty("name").notNull().primaryKey();
        user.addStringProperty("sex");
        //Picture
        Entity picture =  schema.addEntity("Picture");
        picture.addLongProperty("pictureId").primaryKey();
        picture.addStringProperty("pictureName").notNull();
        picture.addIntProperty("width");
        picture.addIntProperty("height");
        //建立一对一关联
        Property property =  user.addLongProperty("pictureId").getProperty();
        user.addToOne(picture,property);

        Property propertyName = picture.addStringProperty("name").getProperty();
        picture.addToOne(user,propertyName);

        new DaoGenerator().generateAll(schema, "../GreenDAODemo/app/src/main/java-gen");
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

【注意】:目前多表关联只能支持关联的表只能有一个主键,所以我们不能加入user.addIdProperty();或者在表中设置了两个主键,因为user.addIdProperty();默认会把id作为主键。所以当你的某张表存在与其它表关联时,你需要检查所关联的那张表是否只设置了一个主键,否则将会报错。

当右键运行生成相应的实体后,我们可以打开User类: 
发现多了一个pictureId属性,这正是User表的外键,Picture的主键,然后构造方法也需要我们传入pictureId的值: 
 
 
User类中还提供了一个getPicture()方法,供我们直接得到当前User的Picture对象而得到相应信息,实际上它内部已经帮我们封装好了相应的查询方法,我们只需直接调用即可: 
 
同样Picture类中也是这样。

一对多关联

大家都知道在超市购物时候,一位顾客可以有很多订单,而一个订单只能属于一位顾客,所以这就成了一对多的关系,假设顾客Customer表有customerId(primaryKey)、name两个属性,订单Order表有orderId(primaryKey)、money两个属性。 
 
所以建立顾客和订单之间的一对多关联为:

        Schema schema = new Schema(1,"com.sunzxyong.greendao3");
        //顾客
        Entity customer = schema.addEntity("Customer");
        customer.addLongProperty("customerId").primaryKey();
        customer.addStringProperty("name").notNull();

        //订单
        Entity order = schema.addEntity("Order");
        order.addLongProperty("orderId").primaryKey();
        order.addDoubleProperty("money").notNull();

        //建立一对多关联(顾客对订单为一对多)
        Property property = order.addLongProperty("customerId").getProperty();
        order.addToOne(customer,property);
        customer.addToMany(order,property).setName("orders");

        new DaoGenerator().generateAll(schema, "../GreenDAODemo/app/src/main/java-gen");
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

当设置了顾客对订单一对多关联后,Order实体(和表)中会多一个属性为customerId,所以通过订单我们可以得到该顾客信息,而Customer实体(和表)中会多一个List集合变量:List<Order> orders,表示该顾客的所有订单,其中orders其实是我们自定义的名字,在刚刚setName("orders")就是给这个变量设置了“orders“名称,而Customer实体中还提供了一个方法getOrders()表示得到该顾客所有订单:

List<Order> orders = customer.getOrders();
  • 1

 
事实上它也是封装好了查询Order中顾客id为customerId的所有订单。

多对多关联

通常来说,在建立多对多关联上,我们都会采用新建一张中间表,利用中间表把多对多这种复杂关系简单化,在通常的选课系统上,一个学生可以选择多门课,一门课可以被多个学生选,这就是多对多关系了,假设Student有studentId、name两个属性,Course有courseId、courseName两个属性,则建立多对多关系为: 

        Schema schema = new Schema(1,"com.sunzxyong.greendao4");
        //学生
        Entity student = schema.addEntity("Student");
        student.addLongProperty("studentId").primaryKey();
        student.addStringProperty("name").notNull();

        //课程
        Entity course = schema.addEntity("Course");
        course.addLongProperty("courseId").primaryKey();
        course.addStringProperty("courseName").notNull();

        //建立多对多关联
        Entity studentCourse = schema.addEntity("StudentCourse");
        Property studentId =  studentCourse.addLongProperty("studentId").getProperty();
        Property courseId =  studentCourse.addLongProperty("courseId").getProperty();
        studentCourse.addToOne(student,studentId);
        studentCourse.addToOne(course,courseId);
        student.addToMany(studentCourse, studentId);
        course.addToMany(studentCourse,courseId);

        new DaoGenerator().generateAll(schema, "../GreenDAODemo/app/src/main/java-gen");
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

这样就建立学生和课程表多对多的关联,学生实体和课程实体中都有这么一个方法:

public List<StudentCourse> getStudentCourseList(){
    //...
}
  • 1
  • 2
  • 3

意思就是得到一个StudentCourse的集合,而StudentCourse实体中又有这么两个方法:

 public Student getStudent(){//...}
 public Course getCourse(){//...}
  • 1
  • 2

所以当我们得到了StudentCourse的List集合,我们可以通过StudentCourse中的这两个方法来得到对应的学生或者课程信息。

原文地址:https://www.cnblogs.com/zhujiabin/p/9078252.html

时间: 2024-10-14 10:50:12

Android ORM对象关系映射之GreenDAO建立多表关联的相关文章

第54篇ORM对象关系映射 如何使用ORM与数据可建立连接

1. ORM(对象关系映射) 很多语言的很多web框架中都有这个概念 2. 为什么要有ORM? 1. 写程序离不开数据. 2. 在Python程序中要用到数据库中的数据,怎么办? 1. 使用pymysql连接MySQL数据库的步骤 1. import pymysql 2. 建立连接 conn = pymysql.connect( host='127.0.0.1', port=3306, database='day43', user='root', password='123', charset=

ORM : 对象关系映射

ORM 对象关系映射(英语:Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”.

ORM对象关系映射

最近开发数据采集模块,数据解析完成之后,插入到数据库中的内存表,原来的同事留下的代码中,出现了大量SQL命令,调用了MySQL的客户端API,整个代码看出来乱乱的,程序效率也不高.很佩服这个同事的精神,使用了这么多的代码,加上很多SQL命令. 为了改进这个模块的设计,提高程序运行效率,查阅了大量的资料后,发现ORM对象关系映射解决了这个问题,避免使用大量的SQL命令,解决了类与数据库的耦合问题.本质就是人家C++高手写好的数据库方便操作的API,不用使用SQL命令,解决数据库存增删改查. 什么是

ORM对象关系映射框架基本搭建

一 概念 1 概念 ORM :对象关系映射,对象和关系之间的映射,使用面向对象的方式来操作数据库 关系对象模型和python对象模型之间的映射 tabel => class ,表映射类 row => object ,行映射为实例 column=> property ,字段映射属性 2 举例 表有login,字段为id int , username varchar, age int 映射到python为 #!/usr/bin/poython3.6 #conding:utf-8 class

Php ORM 对象关系映射

ORM的全称是Object Relational Mapping,即对象关系映射.它的实质就是将关系数据(库)中的业务数据用对象的形式表示出来,并通过面向对象(Object-Oriented)的方式将这些对象组织起来,实现系统业务逻辑的过程.在ORM过程中最重要的概念是映射(Mapping),通过这种映射可以使业务对象与数据库分离.从面向对象来说,数据库不应该和业务逻辑绑定到一起,ORM则起到这样的分离作用,使数据库层透明,开发人员真正的面向对象.图 1简单说明了ORM在多层系统架构中的这个作用

44 MySQL &amp; orm对象关系映射

orm 模型 对象关系映射: Object Relational Mapping 是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换 ORM模型的简单性简化了数据库查询过程 三个核心原则: 简单性:以最基本的形式建模数据:简化了数据库查询过程 传达性:数据库结构被任何人都能理解的语言文档化: 精确性:基于数据模型创建正确标准化的结构. 1)singleton 实现orm mysql_singleton.py import pymysql class Mysql(object)

手撸系列之——ORM(对象关系映射)

ORM:对象关系映射 类 >>> 数据库的一张表 对象 >>> 表的一条记录 对象点属性 >>> 记录某一个字段对应的值 废话不多少,先上代码: # orm.py from mysql_singletion import Mysql # 设置表字段类,通常需要的属性为字段名,字段类型,是否为主键,默认值 class Field(object): def __init__(self,name,column_type,primary_key,default

Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包

Android数据库框架--ORMLite轻量级的对象关系映射(ORM)Java包 事实上,我想写数据库的念头已经很久了,在之前写了一个答题系统的小项目那只是初步的带了一下数据库,数据库是比较强大的,不是我们三言两语就能解决的,我一直想抽个时间自己再过一遍Sqlite和JDBC的,但是,大家也知道,琐事比较多,我们来说一下数据库的框架吧,事实上市面上,我觉得还可以的数据库框架有两个,ORMLite和GreenDao,我以前做的运动类的应用上,就需要存储大量的运动数据,我们最开始是在本地写数据库的

Android数据库框架——GreenDao轻量级的对象关系映射框架,永久告别sqlite

Android数据库框架--GreenDao轻量级的对象关系映射框架,永久告别sqlite 前不久,我在写了ORMLite这个框架的博文 Android数据库框架--ORMLite轻量级的对象关系映射(ORM)Java包 但是对于我个人来说,我可能更加倾向于用GreenDao,所以今天也为大家带来了GreenDao的详细博客,希望大家喜欢,之前也详细介绍了ORM的思想,如果不明白可以先看一下前面的博文,这里就不多赘述了,我们新建一个工程 一.相关介绍 官方网站 : http://greendao