天天看点

深入实践Spring Boot2.1.2 实体建模

<b>2.1.2 实体建模</b>

首先创建一些普通对象,用来与数据库的表建立映射关系,接着演示如何使用jpa对数据库进行增删查改等存取操作。

假如现在有三个实体:部门、用户和角色,并且它们具有一定的关系,即一个用户只能隶属于一个部门,一个用户可以拥有多个角色。它们的关系模型如图2-1所示。

图2-1 mysql实体-关系模型示例

spring boot的实体建模与使用spring框架时的定义方法一样,同样比较方便的是使用了注解的方式来实现。

部门实体的建模如代码清单2-2所示,其中注解@table指定关联的数据库的表名,注解@id定义一条记录的唯一标识,并结合注解@generatedvalue将其设置为自动生成。部门实体只有两个字段:id和name。程序中省略了getter和setter方法的定义,这些方法可以使用idea的自动生成工具很方便地生成。

代码清单2-2 部门实体建模

@entity

@table(name =

"deparment")

public class

deparment {

    @id

    @generatedvalue(strategy =

generationtype.identity)

    private long id;

    private string name;

    public deparment() {

    }

        ……

}

用户实体包含三个字段:id、name和createdate,用户实体建模如代码清单2-3所示。其中注解@manytoone定义它与部门的多对一关系,并且在数据库表中用字段did来表示部门的id,注解@manytomany定义与角色实体的多对多关系,并且用中间表user_role来存储它们各自的id,以表示它们的对应关系。日期类型的数据必须使用注解@datetimeformat来进行格式化,以保证它在存取时能提供正确的格式,避免保存失败。注解@jsonbackreference用来防止关系对象的递归访问。

代码清单2-3 用户实体建模

"user")

user implements java.io.serializable{

    @datetimeformat(pattern = "yyyy-mm-dd

hh:mm:ss")

    private date createdate;

    @manytoone

    @joincolumn(name = "did")

    @jsonbackreference

    private department deparment;

    @manytomany(cascade = {}, fetch =

fetchtype.eager)

    @jointable(name = "user_role",

            joincolumns = {@joincolumn(name =

"user_id")},

            inversejoincolumns =

{@joincolumn(name = "roles_id")})

    private list&lt;role&gt; roles;

    public user() {

……

角色实体建模比较简单,只要按设计的要求,定义id和name字段即可,当然同样必须保证id的唯一性并将其设定为自动生成。角色实体的建模如代码清单2-4所示。

代码清单2-4 角色实体建模

"role")

role implements java.io.serializable{

    public role() {