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

2.1.2 实体建模

首先创建一些普通对象,用来与数据库的表建立映射关系,接着演示如何使用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 用户实体建模

@Entity

@Table(name =
"user")

public class
User implements java.io.Serializable{

    @Id

    @GeneratedValue(strategy =
GenerationType.IDENTITY)

    private Long id;

    private String name;

    @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 角色实体建模

@Entity

@Table(name =
"role")

public class
Role implements java.io.Serializable{

    @Id

    @GeneratedValue(strategy =
GenerationType.IDENTITY)

    private Long id;

    private String name;

 

    public Role() {

    }

……

时间: 2025-01-26 22:15:31

深入实践Spring Boot2.1.2 实体建模的相关文章

深入实践Spring Boot2.4.2 节点和关系实体建模

2.4.2 节点和关系实体建模 虽然Neo4j没有表结构的概念,但它有节点和关系的概念.例如,现在有演员和电影两个实体,它们的关系表现为一个演员在一部电影中扮演一个角色.那么就可以创建演员和电影两个节点实体,和一个角色关系实体.它们的实体-关系模型如图2-5所示.这个实体-关系模型的定义比起关系型数据库的实体-关系模型的定义要简单得多,但是它更加形象和贴切地表现了实体之间的关系.更难能可贵的是,这个实体-关系模型是可以不经过任何转换而直接存入数据库的,也就是说,在Neo4j图数据库中保存的数据与

深入实践Spring Boot2.1.3 实体持久化

2.1.3 实体持久化 通过上面三个实体的定义,实现了使用Java的普通对象(POJO)与数据库表建立映射关系(ORM),接下来使用JPA来实现持久化. 用户实体使用JPA进行持久化的例子如代码清单2-5所示.它是一个接口,并继承于JPA资源库JpaRepository接口,使用注解@Repository将这个接口也定义为一个资源库,使它能被其他程序引用,并为其他程序提供存取数据库的功能. 使用相同的方法,可以定义部门实体和角色实体的资源库接口.接口同样继承于JpaRepository接口,只要

深入实践Spring Boot2.3.2 文档建模

2.3.2 文档建模 MongoDB是文档型数据库,使用MongoDB也可以像使用关系型数据库那样为文档建模.如代码清单2-15所示,为用户文档建模,它具有用户名.密码.用户名称.邮箱和注册日期等字段,有一个用来保存用户角色的数据集,还定义了一个构造函数,可以很方便地用来创建一个用户实例. 代码清单2-15 用户文档建模 @Document(collection = "user") public class User {     @Id     private String userI

深入实践Spring Boot2.2.2 创建Redis服务类

2.2.2 创建Redis服务类 Redis提供了下列几种数据类型可供存取: string: hash: list: set及zset. 在实例中,将使用string即字符串的类型来演示数据的存取操作.对于Redis,Spring Boot没有提供像JPA那样相应的资源库接口,所以只能仿照上一节中Repository的定义编写一个实体User的服务类,如代码清单2-10所示.这个服务类可以存取对象User以及由User组成的列表List,同时还提供了一个删除的方法.所有这些方法都是使用Redis

深入实践Spring Boot2.4.4 Neo4j测试

2.4.4 Neo4j测试 代码清单2-24是Neo4j的数据库配置类,其中@Enable-TransactionManagement启用了事务管理,@EnableNeo4jRe-positories启用了Neo4j资源库并指定了我们定义的资源库接口的位置,在重载的SessionFactory函数中设定了定义实体的位置,这将促使定义的实体被作为域对象导入,RemoteServer设定连接Neo4j服务器的URL.用户名和密码,这些参数要依据安装Neo4j服务器的情况来设置.如果还没有安装Neo4

深入实践Spring Boot2.5 小结

2.5 小结 这一章,我们一口气学习使用了4种数据库:MySQL.Redis.MongoDB.Neo4j,除了Redis以外,都使用了由Spring Boot提供的资源库来访问数据库并对数据库执行了一般的存取操作.可以看出,在Spring Boot框架中使用数据库非常简单.容易,这主要得益于Spring Boot资源库的强大功能,Spring Boot资源库整合了第三方资源,它把复杂的操作变成简单的调用,它把所有"辛苦.繁重的事情"都包揽了,然后将"微笑和鲜花"献给

深入实践Spring Boot2.1 使用MySQL

2.1 使用MySQL 对于传统关系型数据库来说,Spring Boot使用JPA(Java Persistence API)资源库来实现对数据库的操 作,使用MySQL也是如此.简单地说,JPA就是为POJO(Plain Ordinary Java Object)提供持久化的标准规 范,即将Java的普通对象通过对象关系映射(Object-Relational Mapping,ORM)持久化到数据库中.

深入实践Spring Boot2.2.1 Redis依赖配置

2.2.1 Redis依赖配置 需要使用Redis,可在工程的Maven配置中加入spring-boot-starter-redis依赖,如代码清单2-9所示.其中gson是用来转换Json数据格式的工具,mysql是引用了上一节的模块,这里使用2.1节定义的实体对象来存取数据,演示在Redis中的存取操作. 代码清单2-9 Redis模块的Maven依赖配置 <dependencies>     <dependency>         <groupId>org.sp

深入实践Spring Boot2.2.3 Redis测试

2.2.3 Redis测试 如果还没有安装Redis服务器,可以参照本书附录C提供的方法安装,然后在工程的配置文件application.yml中配置连接Redis服务器等参数,如代码清单2-12所示.其中host和port分别表示Redis数据库服务器的IP地址和开放端口,database可以不用指定,由Redis根据存储情况自动选定(注:测试时这些配置是集成在一个配置类中实现的). 代码清单2-12 Redis配置 spring:     redis:     # database: 1