hibernate学习(5)——一对多关系表达
一对多实现
1、 实现类
package com.alice.hibernate02.vo; import java.util.HashSet;
import java.util.Set; public class Customer {
private Integer id;
private String name;
// 一对多:一个客户(当前客户) 拥有 【多个订单】
// * 需要容器存放多个值,一般建议Set (不重复、无序)
// * 参考集合:List、Map、Array等
// ** 建议实例化--使用方便 private Set<Order> orders = new HashSet<Order>();
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;
} public Set<Order> getOrders() {
return orders;
} public void setOrders(Set<Order> orders) {
this.orders = orders;
} }
package com.alice.hibernate02.vo; public class Order {
private Integer id;
private String name;
//多对一:多个订单属于【一个客户】
private Customer customer;
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;
}
public Customer getCustomer() {
return customer;
}
public void setCustomer(Customer customer) {
this.customer = customer;
}
}
2、 配置文件
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.alice.hibernate02.vo">
<class name="Customer" table="t_customer">
<id name="id" column="id">
<generator class="native"></generator>
</id>
<property name="name" column="name" type="string"></property>
<!-- 表达一对多关系中的集合
name:集合的属性名称
inverse: 是否将关系的维护反转给对方. 默认值: false
true: 在Customer 中 放弃维护外键关系 cascade :级联操作
save-update:级联保存,级联修改. 保存A时,同时保存B.
delete:删除A,同时删除B,AB都不存在
delete-orphan:孤儿删除,解除关系,同时将B删除,A存在的。
如果需要配置多项,使用逗号分隔。<set cascade="save-update,delete"> all : save-update 和 delete 整合
all-delete-orphan : 三个整合 -->
<set name="orders">
<!--
key 用来描述外键
column : 外键的值
-->
<key column="cid"></key>
<one-to-many class="Order"/>
</set>
</class>
</hibernate-mapping>
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.alice.hibernate02.vo">
<class name="Order" table="t_order">
<id name="id" column="id">
<generator class="native"></generator>
</id>
<property name="name" column="name" type="string"></property>
<!-- 表达一对多关系中的集合
name:集合的属性名称
inverse: 是否将关系的维护反转给对方. 默认值: false
true: 在Customer 中 放弃维护外键关系 cascade :级联操作
save-update:级联保存,级联修改. 保存A时,同时保存B.
delete:删除A,同时删除B,AB都不存在
delete-orphan:孤儿删除,解除关系,同时将B删除,A存在的。
如果需要配置多项,使用逗号分隔。<set cascade="save-update,delete"> all : save-update 和 delete 整合
all-delete-orphan : 三个整合 -->
<!-- 表达多对一关系
name: 引用的属性名称
column: 外键的列名
class: 我引用的Order的完整类名
-->
<many-to-one name="customer" column="cid" class="Customer"></many-to-one>
</class>
</hibernate-mapping>
3、一对多操作
public void test01() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = new Customer();
cus.setName("alice"); Order o1 = new Order();
o1.setName("apple"); Order o2 = new Order();
o2.setName("banana"); cus.getOrders().add(o1);// 维护关系
cus.getOrders().add(o2);// 维护关系 o1.setCustomer(cus);
o2.setCustomer(cus); session.save(cus);//保存对象
session.save(o1);//保存对象
session.save(o2);//保存对象 tran.commit(); session.close(); }
4、 级联操作(读、理解)
save-update:A保存,同时保存B
delete:删除A,同时删除B,AB都不存在
delete-orphan:孤儿删除,解除关系,同时将B删除,A存在的。
如果需要配置多项,使用逗号分隔。<set cascade="save-update,delete">
all : save-update 和 delete 整合
all-delete-orphan : 三个整合
package com.alice.hibernate02.many; import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test; import com.alice.hibernate02.util.HibernateUtil;
import com.alice.hibernate02.vo.Customer;
import com.alice.hibernate02.vo.Order; //测试 一对多关系
public class ManyTest02 { @Test
//增
//我们希望在保存Customer时,自动将未保存的Orders当中的Order保存
//cascade: save-update
public void test01() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = new Customer();
cus.setName("alice"); Order o1 = new Order();
o1.setName("apple"); Order o2 = new Order();
o2.setName("banana"); cus.getOrders().add(o1);// 维护关系
cus.getOrders().add(o2);// 维护关系 // o1.setCustomer(cus);
// o2.setCustomer(cus); session.save(cus);//保存对象
// session.save(o1);//保存对象
// session.save(o2);//保存对象 tran.commit(); session.close(); }
@Test
//增
//我们希望在保存Customer时,自动将未保存的Orders当中的Order保存
//cascade: save-update
public void test02() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.get(Customer.class, 2);//1条 select for(Order o :cus.getOrders()){// 1条 select
o.setName("mike");// 修改订单
} tran.commit();//因为设置级联修改,自动将订单的修改保存到数据 session.close(); }
//cascade: delete
//删除Customer时 ,会将Customer下的订单一并删除
//inverse : false 6条sql语句
//inverse : true 5条sql语句 比上面少一条维护外键
@Test
public void test03() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.get(Customer.class, 3);//1条 select session.delete(cus);//删除Customer
// 删除两个Order tran.commit();//因为设置级联修改,自动将订单的修改保存到数据 session.close(); }
//cascade: delete
//操作的两方cascade值都为delete
//需要注意: 千万不要在两方都配置 级联删除. 删除任何一方,会导致整个关系链对象全部删除.
@Test
public void test04() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Order o =(Order) session.get(Order.class, 6); session.delete(o);//删除Customer
// 删除两个Order tran.commit();//因为设置级联修改,自动将订单的修改保存到数据 session.close(); } }
package com.alice.hibernate02.many; import java.util.Iterator; import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test; import com.alice.hibernate02.util.HibernateUtil;
import com.alice.hibernate02.vo.Customer;
import com.alice.hibernate02.vo.Order; //测试 一对多关系
public class ManyTest03 {
@Test
//inverse:false
//cascade: delete-orphan 孤儿删除 => 当没有任何外键引用Order时,order 会被删除
public void test02(){
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.get(Customer.class, 4);
Iterator<Order> iter = cus.getOrders().iterator();
//注意: 删除Customer下的订单时,不能使用 c.setOrders(null); c.setOrders(new HashSet());
while(iter.hasNext()){// 遍历Customer下的订单,并将订单删除 => 维护关系
iter.next();
iter.remove();
}
//cascade: all-delete-orphan => 相当于配置 save-update,delete,delete-orphan }
//cascade: all-delete-orphan => 相当于配置 save-update,delete,delete-orphan
@Test
public void fun1(){
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction();
//------------------------------------------------
Customer c = new Customer();
c.setName("tom"); Order o1 = new Order();
o1.setName("肥皂"); Order o2 = new Order();
o2.setName("蜡烛"); c.getOrders().add(o1);//维护关系
c.getOrders().add(o2); //维护关系 session.save(c);
//------------------------------------------------
session.getTransaction().commit();
session.close(); // 游离状态
}
}
hibernate学习(5)——一对多关系表达的更多相关文章
- hibernate实体xml一对多关系映射
单向一对多关系映射: 一个房间对应多个使用者,也就是Room實例知道User實例的存在,而User實例則沒有意識到Room實例. 用户表: package onlyfun.caterpillar; p ...
- hibernate学习(5)——多对多关系映射
1.创建实体和映射 package com.alice.hibernate03.vo; import java.util.HashSet; import java.util.Set; public c ...
- [原创]java WEB学习笔记81:Hibernate学习之路--- 对象关系映射文件(.hbm.xml):hibernate-mapping 节点,class节点,id节点(主键生成策略),property节点,在hibernate 中 java类型 与sql类型之间的对应关系,Java 时间和日期类型的映射,Java 大对象类型 的 映射 (了解),映射组成关系
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- Hibernate中的一对多关系详解(2)
一对多的关系:例如,部门对员工,一个部门可以有多个员工 多对一的关系:例如,员工对部门,多个员工属于一个部门,并且每个员工只能属于一个部门 那么一对多.多对一在数据库中的是怎样表示的呢?好多话都不说了 ...
- 【hibernate学习杂记】维护关系的一方和不维护关系的一方的区别与联系
双向多对一/一对多例子 维护关系一方为User:多方 不维护关系的一方为Group:一方 以下是多方代码: package Hibernate_demo1.Demo8.Entity.OneToMany ...
- hibernate学习(设计一对一 关系 映射)
//主表 package org.crazy.app.domain; import javax.persistence.*; @Entity @Table(name="person_inf& ...
- hibernate框架学习笔记8:一对多关系案例
两个实体类:客户与联系人,一个客户可以有多个联系人 客户类: package domain; import java.util.HashSet; import java.util.Set; //客户实 ...
- Hibernate框架学习(六)——一对多&多对一关系
一.关系表达 1.表中的表达 2.实体中的表达 3.orm元数据中的表达 一对多:(在Customer.hbm.xml中添加) 多对一:(在LinkMan.hbm.xml中添加) 最后别忘了在hibe ...
- Hibernate一对多、多对一的关系表达
一.关系表达: 1.一对多.多对一表的关系: 学生表: 班级表: 在学生表中,学生的学号是主键.在班级表中,班级号是主键,因此,学生表的外键是classno.因此,班级对应学生是一对多,学生对应班级是 ...
随机推荐
- 启动调试IIS时,vs无法在 Web 服务器上启动调试。Web 服务器未能找到请求的资源。 有关详细信息,请单击“帮助”。
问题截图 1.检查 是否设置了本地IIS 2.检查IIS端口是否为80 3.默认网站设置是否正确 可参考,查看网站绑定是否正确
- int main( int argc, char **argv)
1.参数 (有时参数是void) argc是程序运行时参数个数 argv是存储参数的数组,可以用char* argv[],也可以用char **argv. 例如编译一个hello.c的程序 1 #in ...
- yii 常用的多表查询
return $this->model()->getDbConnection()->createCommand() ->select("t.type,t.title, ...
- MEF Parts Sample
namespace Microshaoft.MEF.Contracts { using System; public delegate void ExceptionEventHandler<TS ...
- ExtJS 中自定义类
首先我们来看一看在Javascript中,是怎样自定义类的: var Person = function (name, age) { this.Name = ""; this.Ag ...
- 图像缩放_OpenCv
图像缩放是一种比较简单的图像处理操作,这里给出opencv中的代码, opencv的版本C语言接口 int resize_c() { const char *pstrImageName = " ...
- 利用ipython实现多线程
多线程来批量化处理数据的时候希望简单的应用,使用ipython会很简单 参考这里
- redis数据类型之—List
(1)list 简单介绍 list是一个有序的字符串列表,是使用双向列表实现的,可以实现最新消息排行.消息队列等功能. (2) list 常用命令
- 已解决:ECSHOP安装出现date_default_timezone_get()问题
今天在安装ECSHOP时遇到警告如下: Warning: date_default_timezone_get(): It is not safe to rely on the system's tim ...
- sqlmap和burpsuite绕过csrf token进行SQL注入检测
利用sqlmap和burpsuite绕过csrf token进行SQL注入 转载请注明来源:http://www.cnblogs.com/phoenix--/archive/2013/04/12/30 ...