1. 什么是关联(association)
1.1 关联指的是类之间的引用关系。如果类A与类B关联,那么被引用的类B将被定义为类A的属性。例如:
public class A{
private B b = new B;
public A(){}
}
1.2 关联的分类:关联可以分为一对一、一对多/多对一、多对多关联
关联是有方向的

现在我们就讲的是一对多

把实体及配置文件导入

Order

/**
* hibernate关联关系
* 一对多:一个订单对应多个订单项
* 多对一:多个订单项对应一个订单(注:一个订单项对应一个订单)
* @author Administrator
*
*/
public class Order implements Serializable {
//订单id
private Integer orderId;
//订单编号
private String orderNO; //1.1 关联指的是类之间的引用关系。如果Order与类OrderItem关联,
//那么被引用的OrderItem将被定义为Order 的属性。例如:
private Set<OrderItem> orderitems=new HashSet<OrderItem>(); public Set<OrderItem> getOrderitems() {
return orderitems;
}
public void setOrderitems(Set<OrderItem> orderitems) {
this.orderitems = orderitems;
}
public Integer getOrderId() {
return orderId;
}
public void setOrderId(Integer orderId) {
this.orderId = orderId;
}
public String getOrderNO() {
return orderNO;
}
public void setOrderNO(String orderNO) {
this.orderNO = orderNO;
}
public Order() {
super();
}
@Override
public String toString() {
return "Order [orderId=" + orderId + ", orderNO=" + orderNO + ", orderitems=" + orderitems + "]";
} }

Order.hbm.xml

<?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>
<class name="com.hmc.hibernate02.entity.Order" table="t_order_hb">
<id name="orderId" type="java.lang.Integer" column="order_id">
<!--native:identity(标识列)+sequence(序列) -->
<generator class="native"></generator>
</id>
<property name="orderNO" type="java.lang.String" column="order_no"/>
<!--一方中的主键就是多方中的外键 -->
<!--
select o.*,oi.* from t_order_hb o inner join t_order_item_hb oi
on o.order_id=oi.oid
--> <!--建立关联关系 -->
<!--
name:实体类中定义的属性名,指向多方
cassade:用来控制如何操作关联的持久化对象的 -->
<set name="orderitems" cascade="save-update" inverse="true" table="t_order_item_hb" >
<!-- 指定连接的多方中的外键列 -->
<key column="oid"></key>
<!--指定实体之间的关联关系:一对多 -->
<!--class:指向的是多方的实体类的全路径名 -->
<one-to-many class="com.hmc.hibernate02.entity.OrderItem"/>
</set>
</class> </hibernate-mapping>

OrderItem

/**
* 多个订单项对应一个订单(注意:一个订单项唯一对应一个订单)
* @author Administrator
*
*/
public class OrderItem implements Serializable{
//订单项id
private Integer orderItemId;
//产品id
private Integer productId;
//数量
private Integer quantity;
//外键列
private Integer oid; //1.1 关联指的是类之间的引用关系。如果OrderItem与类Order关联,
//那么被引用的Order将被定义为OrderItem 的属性。例如:
private Order order; public Order getOrder() {
return order;
}
public void setOrder(Order order) {
this.order = order;
}
public Integer getOrderItemId() {
return orderItemId;
}
public void setOrderItemId(Integer orderItemId) {
this.orderItemId = orderItemId;
}
public Integer getProductId() {
return productId;
}
public void setProductId(Integer productId) {
this.productId = productId;
}
public Integer getQuantity() {
return quantity;
}
public void setQuantity(Integer quantity) {
this.quantity = quantity;
}
public Integer getOid() {
return oid;
}
public void setOid(Integer oid) {
this.oid = oid;
}
@Override
public String toString() {
return "OrderItem [orderItemId=" + orderItemId + ", productId=" + productId + ", quantity=" + quantity
+ ", oid=" + oid + "]";
}

OrderItem.hbm.xml

<?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>
<class name="com.hmc.hibernate02.entity.OrderItem" table="t_order_item_hb">
<id name="orderItemId" type="java.lang.Integer" column="order_item_id">
<!--native:identity(标识列)+sequence(序列) -->
<generator class="native"></generator>
</id>
<property name="productId" type="java.lang.Integer" column="product_id"/>
<property name="quantity" type="java.lang.Integer" column="quantity"/>
<property insert="false" update="false" name="oid" type="java.lang.Integer" column="oid"/>
<!--建立关联关系 -->
<!-- name:实体类中定义的属性名,指向一方 -->
<many-to-one name="order" cascade="save-update" class="com.hmc.hibernate02.entity.Order">
<!--多方的数据库表中的外键列,指向一方 -->
<column name="oid"></column>
</many-to-one> </class> </hibernate-mapping>

OrderDao

 public void add(Order order) {
Session session = SessionFactoryUtils.openSession();
Transaction transaction = session.beginTransaction();
session.save(order);
transaction.commit();
SessionFactoryUtils.closeSession();
} public Order get(Order order) {
Session session = SessionFactoryUtils.openSession();
Transaction transaction = session.beginTransaction();
Order o = session.get(Order.class, order.getOrderId());
//处理懒加载
if(null!=o) {
Hibernate.initialize(o.getOrderitems());
}
transaction.commit();
SessionFactoryUtils.closeSession();
return o;
} public void update(Order order){ Session session = SessionFactoryUtils.openSession();
Transaction transaction = session.beginTransaction();
//先查,再更新
Order o = session.get(Order.class, order.getOrderId());
if(null!=o) {
//拿到多方
Set<OrderItem> orderitems = o.getOrderitems(); OrderItem orderItem=null;
for (int i = 0; i <=2; i++) {
orderItem=new OrderItem();
orderItem.setProductId(i);
orderItem.setQuantity(i+2); //建立关联关系
orderItem.setOrder(o);
o.getOrderitems().add(orderItem);
}
session.update(o);
}
transaction.commit();
SessionFactoryUtils.closeSession(); } //级联删除
public void delete(Order order) {
Session Session = SessionFactoryUtils.openSession();
Transaction Transaction = Session.beginTransaction();
//先查询,在删除
Order o = Session.get(Order.class, order.getOrderId());
if(null!=o) { /**
* 解除关联关系:先删从表,再删主表
* 1)禁用联级删除
* 2)先删从表,再删主表
* 3)手动代码维护
*/
Set<OrderItem> orderitems = o.getOrderitems();
for (OrderItem orderItem : orderitems) {
Session.delete(orderItem);
}
Session.delete(o);
} Transaction.commit();
SessionFactoryUtils.closeSession();
}

测试类进行测试OrderDaoTest

Hibernate:
select
order0_.order_id as order_id1_0_0_,
order0_.order_no as order_no2_0_0_
from
t_order_hb order0_
where
order0_.order_id=?
Hibernate:
select
orderitems0_.oid as oid4_1_0_,
orderitems0_.order_item_id as order_it1_1_0_,
orderitems0_.order_item_id as order_it1_1_1_,
orderitems0_.product_id as product_2_1_1_,
orderitems0_.quantity as quantity3_1_1_,
orderitems0_.oid as oid4_1_1_
from
t_order_item_hb orderitems0_
where
orderitems0_.oid=?
Hibernate:
delete
from
t_order_item_hb
where
order_item_id=?
Hibernate:
delete
from
t_order_item_hb
where
order_item_id=?
Hibernate:
delete
from
t_order_item_hb
where
order_item_id=?
Hibernate:
delete
from
t_order_hb
where
order_id=?

hibernate之一对多关系的更多相关文章

  1. Hibernate的关联映射关系

    一:多对一 <many-to-one 1.name:当前类的属性名(关联映射的类) 2.column:属性多对应的类的对应的表的外键(连接条件) 3.class:属性所对应的类的权限定名 4.n ...

  2. Hibernate与Jpa的关系(2)

    [转自:http://blog.163.com/hero_213/blog/static/398912142010312024809/ ] 近年来ORM(Object-Relational Mappi ...

  3. Hibernate One-to-One Mappings 一对一关系映射

    Hibernate One-to-One Mappings 一对一关系映射 关键:一对一关系映射和多对一关系映射非常像.仅仅是unique 属性值为 true 样例:一个员工仅仅能有一个地址. Hib ...

  4. 【hibernate】映射继承关系

    [hibernate]映射继承关系 转载:https://www.cnblogs.com/yangchongxing/p/10405151.html ========================= ...

  5. 如何决解项目中hibernate中多对多关系中对象转换json死循环

    先写一下原因吧!我是写的SSH项目,在项目中我遇到的问题是把分页对象(也就是pageBean对象)转化为json数据,下面为代码: public class PageBean <T>{// ...

  6. hibernate学习四(关系映射一对一与组件映射)

    一.关系映射简介 在数据库中,表与表的关系,仅有外键.但使用hibernate后,为面向对象的编程,对象与对象的关系多样化:如 一对一,一对多,多对多,并具有单向和双向之分. 开始练习前,复制上一次项 ...

  7. hibernate笔记--继承映射关系的三种实现方式

    单表继承映射(一张表): 假设我们现在有三个类,关系如下: Person类有两个子类Student和Teacher,并且子类都具有自己独有的属性.这种实体关系在hibernate中可以使用单表的继承映 ...

  8. hibernate中一对多关系中的inverse,cascade属性

    举例说明: 一对多关系的两张表:boy.girl(一个男孩可以多个女朋友) boy表结构 Field   Type        ------  -----------  name    varcha ...

  9. Hibernate双向多对多对象关系模型映射

    1 双向many-to-many 业务模型: 描述员工和项目 一个员工同时可以参与多个项目 一个项目中可以包含多个员工 分析:数据库的数据模型,通过中间关系表,建立两个one-to-many构成man ...

  10. Hibernate单向一对多对象关系模型映射

    1 hibernate 的对象关系映射 Orm: 类-----表 属性------字段 对象------记录 表:在数据库中存在主外键的关系,反向工厂类是由表生成,在由表生成类的时候,类和类之间存在者 ...

随机推荐

  1. 解决html 图片缓存问题

    <!--问题:上传一张图片,通过js更新src属性刷新图片使其即时显示时, 当img的src当前的url与上次地址无变化时(只更改图片,名称不变,不同图片名称相同)图片不变化(仍显示原来的图片) ...

  2. 3. ABP .NETCore 添加企业微信第三方登录

    1.企业微信登录步骤 1.获取企业微信Token 官方文档:https://work.weixin.qq.com/api/doc#90000/90135/91039 2.通过Token 与前端传的Co ...

  3. K-匿名算法研究

    12月的最后几天,研究了下k匿名算法,在这里总结下. 提出背景 Internet 技术.大容量存储技术的迅猛发 展以及数据共享范围的逐步扩大,数据的自动采集 和发布越来越频繁,信息共享较以前来得更为容 ...

  4. 1.Tomcat组件梳理—Bootstrap启动器

    Tomcat组件梳理-Bootstrap启动器 一开始是直接从Server开始做梳理的,但是发现有很多东西是从Catalina传输过来的,Catalina又是从Bootstrap启动的,所以还是回过头 ...

  5. vue 利用v-model实现父子组件数据双向绑定

    v-model父组件写法: v-model子组件写法: 子组件export default中的model:{}里面两个值,prop代表着我要和props的那个变量相对应,event表示着事件,我触发事 ...

  6. JavaWeb 之 BeanUtils 工具类

    在上一个用户登录案例中,当从浏览器接收参数后,还需要创建 JavaBean 类,对其的属性每一项赋值,如果属性少,可以手动完成,但是当属性非常多,这时就发现非常不方便,在这里提供一个可以封装 Java ...

  7. 《Spring in Action 4》阅读札记

    重要思路 Spring通过面向POJO编程.依赖注入.AOP和模板技术来降低Java开发的复杂性. 依赖注入能够让互相协作的软件组件保持松耦合,模块直接的耦合性是必要的,否则没法完成工作,但是耦合性需 ...

  8. CspParameters 对象已存在异常 解决多应用对同一容器的访问问题

    CspParameters cspParams; cspParams = new CspParameters(PROVIDER_RSA_FULL); cspParams.KeyContainerNam ...

  9. nodejs SSL Error: CERT_UNTRUSTED while using npm command 错误

    SSH 使用错误,其实我们关掉HTTPS就好了 npm config set strict-ssl false 或者 npm config set registry="http://regi ...

  10. GDI双缓冲

    GDI双缓冲 翻译自Double buffering,原作者Dim_Yimma_H 语言:C (原文写的是C++,实际上是纯C) 推荐知识: 构建程序 函数 结构体 变量和条件语句 switch语句 ...