spring boot jpa 多表关联 @OneToOne @OneToMany @ManyToOne@ManyToMany
1.一对一关联 @OneToOne
import lombok.Data; import javax.persistence.*; /**
* @Author: GWL
* @Description: 一对一
* @Date: Create in 23:10 2019/5/10
*/
@Entity
@Table(name = "t_girlfriend")
@Data
public class Girlfriend { @Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "g_id")
private int id; @Column(name = "g_name")
private String name; @Column(name = "g_age")
private int age; @Column(name = "g_sweet")
private String sweet; @Temporal(value=TemporalType.TIMESTAMP)
@Column(name = "create_date")
private java.util.Date createDate; @OneToOne
@JoinColumn(name = "t_boyfriend")
private Users user; }
2.多对一和一对多 @ManyToOne
import lombok.Data; import javax.persistence.*; /**
* @Author: GWL
* @Description: 用户表
* @Date: Create in 22:40 2019/5/3
*
*/
@Entity
@Table(name="user")
@Data
public class Users {
/**
*
* 一个角色多个用户
* @JoinColumn 维护外键
*/
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "user_id")
private int id; @Column(name = "user_name")
private String name; @Column(name = "user_age")
private int age; @Temporal(value=TemporalType.TIMESTAMP)
@Column(name = "create_date")
private java.util.Date createDate; @ManyToOne(cascade = CascadeType.PERSIST)
@JoinColumn(name = "r_id")
private Roles roles; }
@OneToMany
import lombok.Getter;
import lombok.Setter; import javax.persistence.*;
import java.util.HashSet;
import java.util.Set; /**
* @Author: GWL
* @Description: 角色表 与用户表一对多,角色表与菜单表多对多
* @Date: Create in 19:06 2019/5/8
*/
@Entity
@Table(name="t_roles")
@Getter
@Setter
public class Roles { @Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "role_id")
private int roleId; @Column(name = "role_name")
private String roleName; @Column(name = "note")
private String note; @OneToMany(mappedBy = "roles")
private Set<Users> users = new HashSet<>(); @ManyToMany(cascade = CascadeType.PERSIST,fetch = FetchType.EAGER)
@JoinTable(name = "t_roles_menu",joinColumns = @JoinColumn(name = "role_id"),inverseJoinColumns = @JoinColumn(name = "menu_id"))
private Set<Menu> menus = new HashSet<>(); @Override
public String toString() {
return "Roles{" +
"roleid=" + roleId +
", roleName='" + roleName + '\'' +
", note='" + note + '\'' +
'}';
}
}
3.多对多 @ManyToMany
import lombok.Getter;
import lombok.Setter; import javax.persistence.*;
import java.util.HashSet;
import java.util.Set; /**
* @Author: GWL
* @Description: 角色表 与用户表一对多,角色表与菜单表多对多
* @Date: Create in 19:06 2019/5/8
*/
@Entity
@Table(name="t_roles")
@Getter
@Setter
public class Roles { @Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "role_id")
private int roleId; @Column(name = "role_name")
private String roleName; @Column(name = "note")
private String note;
@ManyToMany(cascade = CascadeType.PERSIST,fetch = FetchType.EAGER)
@JoinTable(name = "t_roles_menu",joinColumns = @JoinColumn(name = "role_id"),inverseJoinColumns = @JoinColumn(name = "menu_id"))
private Set<Menu> menus = new HashSet<>(); @Override
public String toString() {
return "Roles{" +
"roleid=" + roleId +
", roleName='" + roleName + '\'' +
", note='" + note + '\'' +
'}';
}
}
import lombok.Data; import javax.persistence.*;
import java.util.HashSet;
import java.util.Set; /**
* @Author: GWL
* @Description: 多对多 菜单表与角色表
* @Date: Create in 18:47 2019/5/9
*/
@Entity
@Table(name = "t_menu")
@Data
public class Menu { @Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "menu_id")
private int menuId; @Column(name = "menu_name")
private String menuName; @Column(name = "menu_url")
private String menuUrl; @Column(name = "menu_fid")
private int fatherId; @ManyToMany(mappedBy = "menus")
Set<Roles> roles = new HashSet<>(); }
有兴趣的朋友可以查看本人spring-boot-jpa GitHub项目
spring boot jpa 多表关联 @OneToOne @OneToMany @ManyToOne@ManyToMany的更多相关文章
- Spring Boot JPA中关联表的使用
文章目录 添加依赖 构建Entity 构建Repository 构建初始数据 测试 Spring Boot JPA中关联表的使用 本文中,我们会将会通过一个Book和Category的关联关系,来讲解 ...
- Spring Boot + JPA(hibernate 5) 开发时,数据库表名大小写问题
(转载)Spring Boot + JPA(hibernate 5) 开发时,数据库表名大小写问题 这几天在用spring boot开发项目, 在开发的过程中遇到一个问题hibernate在执 ...
- Spring Boot Jpa 表名小写转大写
今天在使用SpringBoot整合Hibernate后创建表,表名为小写,而在linux下,mysql的表名是区分大小写的,因此在我的数据表中,就出现了两个一样的表 act_id_user 和 AC ...
- Spring Boot(五):Spring Boot Jpa 的使用
在上篇文章Spring Boot(二):Web 综合开发中简单介绍了一下 Spring Boot Jpa 的基础性使用,这篇文章将更加全面的介绍 Spring Boot Jpa 常见用法以及注意事项. ...
- Spring Boot Jpa 的使用
Spring Boot Jpa 介绍 首先了解 Jpa 是什么? Jpa (Java Persistence API) 是 Sun 官方提出的 Java 持久化规范.它为 Java 开发人员提供了一种 ...
- (转)Spring Boot(五):Spring Boot Jpa 的使用
http://www.ityouknow.com/springboot/2016/08/20/spring-boot-jpa.html 在上篇文章Spring Boot(二):Web 综合开发中简单介 ...
- Spring Boot(十五):spring boot+jpa+thymeleaf增删改查示例
Spring Boot(十五):spring boot+jpa+thymeleaf增删改查示例 一.快速上手 1,配置文件 (1)pom包配置 pom包里面添加jpa和thymeleaf的相关包引用 ...
- spring boot JPA中实体类常用注解
spring boot jpa中的注解很多,参数也比较多.没必要全部记住,但是经常查看官方文档也比较麻烦,记录一下一些常用的注解.通过一些具体的例子来帮助记忆. @Entity @Table(name ...
- Spring boot Jpa添加对象字段使用数据库默认值
Spring boot Jpa添加对象字段使用数据库默认值 jpa做持久层框架,项目中数据库字段有默认值和非空约束,这样在保存对象是必须保存一个完整的对象,但在开发中我们往往只是先保存部分特殊的字段其 ...
随机推荐
- mysql三种连接方式
sql四种连接方式demo: 表a 表b a.id与b.parent_id有关系 1.内连接:SELECT a.*,b.* from a INNER JOIN b ON a.id=b.parent_i ...
- Django框架(十五)—— forms组件、局部钩子、全局钩子
目录 forms组件.局部钩子.全局钩子 一.什么是forms组件 二.forms组件的使用 1.使用语法 2.组件的参数 3.注意点 三.渲染模板 四.渲染错误信息 五.局部钩子 1.什么是局部钩子 ...
- c# 关于DataTable
1.DataRow数组 转DataTable using (SqlConnection con = new SqlConnection("server=.;uid=sa;pwd=123;da ...
- python获取Linux发行版名称
我必须从Python脚本中获取Linux发行版名称.dist平台模块中有一个方法: import platform platform.dist() 但在我的Arch Linux下它返回: >&g ...
- 初探Remoting双向通信(三)
原 初探Remoting双向通信(三) 2013年06月25日 17:51:08 喜欢特别冷的冬天下着雪 阅读数 4741 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blo ...
- 从一个url地址到最终页面渲染完成,发生了什么?
从一个url地址到最终页面渲染完成,发生了什么? 1.DNS 解析 : 将域名地址解析为IP地址 浏览器DNS缓存 系统DNS缓存 路由器DNS缓存 网络运营商DNS缓存 递归搜索: www.baid ...
- 在egg中配置 sequelize
如何在eggjs中引入 sequlize 安装 第一步,在项目中安装 egg-sequelize插件和mysql插件 npm install --save egg-sequelize mysql2 第 ...
- 请问如何实现字符串UTF8->BIG5,BIG5->UTF8。保证送分。-Java/JavaSE
请问如何实现字符串UTF8-> BIG5,BIG5-> UTF8. ------回答--------- ------其他回答(100分)--------- public String BI ...
- jsp service bean
//在jsp中使用后台service中方法需要在jsp页面引入service bean 1 <%@page import="com..entity.Users"%> & ...
- 6371. 【NOIP2019模拟2019.9.28】基础图论练习题
题目 题目大意 维护一个无向图的割边条数,支持加边和删边. 正解 (PS:这是我很久之前在OJ上打出来的题解,现在直接copy过来) 题解只有一句话,估计没多少人可以看得懂.感觉出题人偷懒不想写题解- ...