JPA(七):映射关联关系------映射双向多对一的关联关系

映射双向多对一的关联关系

修改Customer.java

package com.dx.jpa.singlemanytoone;import java.util.Date;
import java.util.HashSet;
import java.util.Set;import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.Transient;@Entity
@Table(name = "jpa_customer")
public class Customer {private Integer id;private String fullName;private Integer age;private Date birth;private Date createDate;private Set<Order> orders = new HashSet<>();@Id@GeneratedValue(strategy = GenerationType.AUTO)public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}@Column(name = "FULL_NAME", length = 64, nullable = false)public String getFullName() {return fullName;}public void setFullName(String fullName) {this.fullName = fullName;}public Integer getAge() {return age;}public void setAge(Integer age) {this.age = age;}@Temporal(TemporalType.DATE)public Date getBirth() {return birth;}public void setBirth(Date birth) {this.birth = birth;}@Temporal(TemporalType.TIMESTAMP)public Date getCreateDate() {return createDate;}public void setCreateDate(Date createDate) {this.createDate = createDate;}// 映射一对多的关联关系// @JoinColumn 用来映射一对多的关联关系// @OneToMany 用来映射外键列@JoinColumn(name = "CUSTOMER_ID")@OneToMany(fetch=FetchType.EAGER,cascade=CascadeType.REMOVE)public Set<Order> getOrders() {return orders;}public void setOrders(Set<Order> orders) {this.orders = orders;}// 帮助方法,不希望保存到数据库,但是需要动态获取Customer对象的属性。
    @Transientpublic String getCustomerInfo() {return "username:" + fullName + ",age:" + age;}
}
View Code

修改Order.java

package com.dx.jpa.singlemanytoone;import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;@Entity
@Table(name = "jpa_order")
public class Order {private Integer id;private String name;private Customer Customer;@Id@GeneratedValue(strategy = GenerationType.AUTO)public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}@JoinColumn(name = "CUSTOMER_ID")@ManyToOne(fetch = FetchType.LAZY)public Customer getCustomer() {return Customer;}public void setCustomer(Customer customer) {Customer = customer;}
}
View Code

修改persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"><persistence-unit name="Jpa-helloword"transaction-type="RESOURCE_LOCAL"><!-- 配置使用什么 ORM 产品来作为 JPA 的实现 --><provider>org.hibernate.jpa.HibernatePersistenceProvider</provider><!-- 添加持久化类 --><class>com.dx.jpa.singlemanytoone.Customer</class><class>com.dx.jpa.singlemanytoone.Order</class><properties><!-- 数据库的相关配置 --><property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" /><property name="javax.persistence.jdbc.url" value="jdbc:mysql://127.0.0.1:3306/jpa" /><property name="javax.persistence.jdbc.user" value="root" /><property name="javax.persistence.jdbc.password" value="root" /><!-- 指定方言 MySQL                org.hibernate.dialect.MySQLDialectMySQL with InnoDB    org.hibernate.dialect.MySQLInnoDBDialectMySQL with MyISAM    org.hibernate.dialect.MySQLMyISAMDialectMySQL5                org.hibernate.dialect.MySQL5DialectMySQL5 with InnoDB    org.hibernate.dialect.MySQL5InnoDBDialect--><property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" /><property name="hibernate.show_sql" value="true" /><property name="hibernate.format_sql" value="true" /><!-- create:每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。<br>create-drop :每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。<br>update:最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等 应用第一次运行起来后才会。<br>validate :每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。 <br> --><property name="hibernate.hbm2ddl.auto" value="update" />            </properties></persistence-unit>
</persistence>
View Code

特别注意:配置双向多对一的关联关系时,Customer.java配置:

    // 映射一对多的关联关系// @JoinColumn 用来映射一对多的关联关系// @OneToMany 用来映射外键列@JoinColumn(name = "CUSTOMER_ID")@OneToMany(fetch=FetchType.EAGER,cascade=CascadeType.REMOVE)public Set<Order> getOrders() {return orders;}

Order.java配置:

    @JoinColumn(name = "CUSTOMER_ID")@ManyToOne(fetch = FetchType.LAZY)public Customer getCustomer() {return Customer;}

表关联关系:

测试添加:

添加测试函数:

    @Testpublic void testPersist() {Customer customer = new Customer();customer.setFullName("AA");customer.setAge(26);customer.setBirth(new Date());customer.setCreateDate(new Date());Order order1 = new Order();order1.setName("O-AA-01");Order order2 = new Order();order2.setName("O-AA-02");customer.getOrders().add(order1);customer.getOrders().add(order2);order1.setCustomer(customer);order2.setCustomer(customer);entityManager.persist(customer);entityManager.persist(order1);entityManager.persist(order2);}

执行sql::

Hibernate: selectnext_val as id_val fromhibernate_sequence for updateHibernate: updatehibernate_sequence setnext_val= ? wherenext_val=?
Hibernate: selectnext_val as id_val fromhibernate_sequence for updateHibernate: updatehibernate_sequence setnext_val= ? wherenext_val=?
Hibernate: selectnext_val as id_val fromhibernate_sequence for updateHibernate: updatehibernate_sequence setnext_val= ? wherenext_val=?
Hibernate: insert intojpa_customer(age, birth, createDate, FULL_NAME, id) values(?, ?, ?, ?, ?)
Hibernate: insert intojpa_order(CUSTOMER_ID, name, id) values(?, ?, ?)
Hibernate: insert intojpa_order(CUSTOMER_ID, name, id) values(?, ?, ?)
Hibernate: updatejpa_order setCUSTOMER_ID=? whereid=?
Hibernate: updatejpa_order setCUSTOMER_ID=? whereid=?
View Code

测试查询:

测试查询函数:

    @Testpublic void testFind() {Customer customer = entityManager.find(Customer.class, 1);System.out.println(customer.getFullName());System.out.println(customer.getOrders().size());}

执行sql语句:

Hibernate: selectcustomer0_.id as id1_0_0_,customer0_.age as age2_0_0_,customer0_.birth as birth3_0_0_,customer0_.createDate as createDa4_0_0_,customer0_.FULL_NAME as FULL_NAM5_0_0_,orders1_.CUSTOMER_ID as CUSTOMER3_1_1_,orders1_.id as id1_1_1_,orders1_.id as id1_1_2_,orders1_.CUSTOMER_ID as CUSTOMER3_1_2_,orders1_.name as name2_1_2_ fromjpa_customer customer0_ left outer joinjpa_order orders1_ on customer0_.id=orders1_.CUSTOMER_ID wherecustomer0_.id=?
BB
2

测试修改:

测试修改函数:

 

执行sql语句:

 

测试删除:

 

4)映射双向一对一的关联关系

5)映射双向多对多的关联关系

转载于:https://www.cnblogs.com/yy3b2007com/p/9231272.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/366667.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何优雅的绘制一棵省市区三级可选择的树?

开始 总结一下 开发过程中的思路想法 各位大佬们看看就好 首先你拥有的数据结构 所有省市区的信息列表 以及已经选中的信息 用的是element-ui的 el-tree const cityStorage {provinceList:[{id: 1, provinceId: "110000", name: "北京市"}],//所有省ci…

html click事件 参数,vue 实现click同时传入事件对象和自定义参数

这篇文章主要介绍了vue 实现click同时传入事件对象和自定义参数&#xff0c;具有很好的参考价值&#xff0c;希望对大家有所帮助。一起跟随小编过来看看吧仅仅传入自定义参数HTMLdddddJS代码new Vue({el:#app,methods:{tm:function(e){console.log(e);}}})仅仅传入事件对象HTML…

向SAML响应中添加自定义声明–(如何为WSO2 Identity Server编写自定义声明处理程序)...

总览 最新版本的WSO2 Identity Server&#xff08;版本5.0.0&#xff09;配备了“应用程序身份验证框架”&#xff0c;该框架提供了很大的灵活性&#xff0c;可以对来自使用异构协议的各种服务提供商的用户进行身份验证。 它具有多个扩展点&#xff0c;可用于满足企业系统中常见…

Android学习(七)—— Android布局

Android布局 1、LinearLayout 线性布局&#xff0c;这种布局在平时的开发中用的最多&#xff0c;内部控件只能水平或竖直进行排列&#xff0c;在搭建较复杂的界面时会有点麻烦。 常用属性 android:orientation 控制控件排列方向&#xff0c;属性值为垂直&#xff08;vertical…

不一样的ZTree,权限树.js插件

每一个有趣的创新&#xff0c;都源于苦逼的生活。在最近的工作中&#xff0c;遇到一个做权限管理筛选的需求。 简单总结需求&#xff1a; 1展示一个组织中的组织结构 2通过点击组织结构中的任意一个节点可以向上向下查询对应的组织结构 如果你不想苦逼的重复劳动&#xff0c;还…

No goals have been specified for this build.

解决办法&#xff0c;在pom.xml添加如下配置&#xff1a; <build><defaultGoal>compile</defaultGoal> </build> 转载于:https://www.cnblogs.com/penghq/p/9233655.html

JavaFX 2:如何加载图像

这是有关如何在JavaFX 2应用程序中加载图像的JavaFX教程。 使用ImageView可以轻松完成此操作。 ImageView是一个节点&#xff0c;用于绘制加载有Image类的图像。 因此&#xff0c;您将首先使用Image类加载图像&#xff0c;然后使用ImageView显示它。 我还将在这里演示如何从本地…

JavaScript DOM介绍

DOM 概念 所谓DOM,全称 Docuemnt Object Model 文档对象模型&#xff0c;毫无疑问&#xff0c;此时要操作对象&#xff0c;什么对象&#xff1f;文档对象 在文档中一切皆对象&#xff0c;比如html,body,div,p等等都看做对象&#xff0c;那么我们如何来点击某个盒子让它变色呢&a…

html实现拖拽排序,简单的jquery拖拽排序效果实现代码

步骤&#xff1a;1.实现随鼠标移动的效果&#xff1b;2.初始化一个元素及其坐标&#xff1b;3.拖拽对象的最后坐标&#xff0c;与元素的坐标 进行计算和判断 来确定 要插入的目标元素&#xff1b;4.用insertBefore 方法 插入到目标元素的前面具体代码如下&#xff1a;测试的拖拽…

记HTML5 a 标签的一个小坑

今天写了段简单的代码&#xff0c;点击<a>标签时却抛出了这个错误&#xff1a;Uncaught TypeError: download is not a function。代码如下&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><…

HashMap遍历,取出key和value

HashMap的遍历有两种常用的方法&#xff0c;那就是使用keyset及entryset来进行遍历,在用keySet(key)取value时候&#xff0c;需要key 第一种:  Map map new HashMap();  Iterator iter map.entrySet().iterator();  while (iter.hasNext()) {   Map.Entry entry …

C#线程 ---- 线程同步详解

线程同步 说明&#xff1a;接上一篇&#xff0c;注意分享线程同步的必要性和线程同步的方法。 测试代码下载&#xff1a;https://github.com/EkeSu/C-Thread-synchronization-C-.git 一、什么是线程同步&#xff1a; 在同一时间只允许一个线程访问资源的情况称为线程同步。 二、…

Spring中的类型转换

以下是一些需要类型转换的简单情况&#xff1a; 情况1。 为了帮助简化bean配置&#xff0c;Spring支持属性值与文本值之间的转换。 每个属性编辑器仅设计用于某些类型的属性。 为了使用它们&#xff0c;我们必须在Spring容器中注册它们。 案例2。 同样&#xff0c;在使用Sprin…

响应式方案调研及前端开发管理思考

网易首页响应式风格实现技术调研网易首页实现页面&#xff08;字体&#xff09;响应式风格的方式是在不同尺寸的视口中使用不同的容器类&#xff0c;如图 1所示。当视口大于等于1420px时&#xff0c;使用大尺寸容器类 &#xff08;index2017_1200_wrap&#xff0c;width: 1200p…

响应式html编辑器布局,基于Bootstrap响应式所见即所得的jQuery编辑器插件

LineControl Editor是一款基于Bootstrap的响应式、所见即所得的富文本编辑器jQuery插件。该富文本编辑器可以使用textarea元素或任何一个容器元素来生成&#xff0c;它拥有常见富文本编辑器的所有功能&#xff0c;使用快捷方便。插件依赖该富文本编辑器插件依赖于jQuery2.1.0和…

linux nexus启动_Linux一键部署Nexus 3私服仓库自动化部署脚本

此脚本是Linux一键部署Nexus 3私服仓库自动化脚本&#xff0c;有需要朋友可以参考&#xff0c;脚本内容如下&#xff1a;环境准备&#xff1a;操作系统&#xff1a;CentOS Linux release 7.8.2003软件版本&#xff1a;Docker&#xff1a;docker-ce-19.03.12[rootlocalhost ~]# …

zabbix 模板 创建逻辑 + 主动模式-被动模式

模板通常包含了item、trigger、graph(图形)、application以及low-level discovery rule&#xff1b;模板可以直接链接至某个主机&#xff1b; 模板包含一系列的item&#xff0c;trigger等&#xff0c;可以快速地把多个item应用到host或者group。 参考&#xff1a;https://www.c…

JavaFX中的塔防(3)

在最后一部分中&#xff0c;您了解了如何创建Sprite&#xff0c;为其设置动画并赋予其Behavior。 但是动画效果不是很好&#xff0c;因为作为Insectoid&#xff0c;您应该始终看起来在飞行中。 记住&#xff1a;安全第一&#xff01; 我们可以通过创建自定义的TileSetAnimation…

day21 pickle json shelve configpaser 模块

1. 序列化:我们在网络传输的时候,需要我们对对象进行处理,把对象处理成方便存储和传输的格式,这个过程就叫序列化 序列化的方法不一定一样,三十目的都是为了方便储存和传输. 在python中有三种序列化方案: 1. pickle 可以将我们python中任意数据类型转化为bytes写入文件中…

flex.css快速入门,极速布局

什么是flex.css? css3 flex 布局相信很多人已经听说过甚至已经在开发中使用过它&#xff0c;但是我想我们都会有一个共同的经历&#xff0c;面对它的各种版本&#xff0c;各种坑&#xff0c;傻傻的分不清楚&#xff0c;flex.css就是对flex布局的一种封装&#xff0c;通过简洁…