<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<role> roles;
public user() {
……
角色实体建模比较简单,只要按设计的要求,定义id和name字段即可,当然同样必须保证id的唯一性并将其设定为自动生成。角色实体的建模如代码清单2-4所示。
代码清单2-4 角色实体建模
"role")
role implements java.io.serializable{
public role() {