多对一:比如多个订单对应同一个用户,需要在订单表中添加一个用户的属性

订单类:

private Integer orderId;
private Date createTime;
private User user;

用户类:

private int userId;
private String userName;
private String userPsw;

一的方配置xml(user):

<?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="ni.jun.yang.bean.User" table="t_user">
<id name="userId">
<!-- 主键自动增长 -->
<generator class="native"></generator>
</id>
<property name="userName"></property>
<property name="userPsw"></property>
</class>
</hibernate-mapping>

多的一方配置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="ni.jun.yang.bean.Orders" table="t_order">
<id name="orderId" column="orderId">
<generator class="native"></generator>
</id>
<property name="createTime" type="date"></property> <!-- 多个订单对应一个用户,配置多对一的映射 cascade级联-->
<many-to-one name="user" class="ni.jun.yang.bean.User" column="userId" cascade="all">
</many-to-one>
</class>
</hibernate-mapping>
 <many-to-one name="user" class="ni.jun.yang.bean.User" column="userId"  cascade="all">  
name:类中的成员变量名字
class:对应类的全路径,配了包名只需要写类名即可
column:数据库里面的字段名字
cascade:级联 其值有“all”,“save-update”,“delete”等 测试代码:由于配置级联 cascade=‘all’,保存订单会首先自动保存级联的用户对象
Session session =  HibernateUtil.getSessionFactory().openSession();
Transaction ts = session.beginTransaction();
User user = new User();
user.setUserName("不知3");
user.setUserPsw("4563"); Orders orders1 =new Orders();
orders1.setCreateTime(new Date());
orders1.setUser(user); session.save(orders1);
ts.commit();
session.close();

一对多:比如一个人可以有多张银行卡

一的一方需要设置一个 集合来存放多的一方 使用list 或者set集合,一般多用set集合

如:一个人有多个地址,list集合存放

private List<String> addresses;

xml配置:list用list标签,要配置索引 list-index

<list name="addresses" table="address">
<key column="customerId"></key>
<!-- 用list需要配list索引,相当于下标从0开始 -->
<list-index column="ListIndex"></list-index>
<element type="string" column="addressName"></element>
</list>

set集合存放:

private Set<String> addresses;

xml配置:set用set标签

<set name="addresses" table="address" sort="natural">
<key column="customerId"></key>
<element type="string" column="addressName"></element>
</set>

双向一对多:如一个人有多套房,他就有多个地址

customer:

private Integer customerId;
private String customerName;
private Set<Address> adresses;

address:

private Customer customer;
private Integer addressId;
private String address;

customer  xml配置:

<!-- inverse=true 放弃关联关系维护,默认false,关系维护-->
<set name="adresses" table="_Address" inverse="true" cascade="save-update">
<key column="customerId"></key>
<one-to-many class="ni.jun.yang.bean.Address" />
</set>

address  xml配置

<many-to-one name="customer" class="Customer" column="customerId"></many-to-one>

测试代码:

Session session =  HibernateUtil.getSessionFactory().openSession();
Transaction ts = session.beginTransaction();
Address address1 = new Address();
address1.setAddress("青羊区");
Address address2 = new Address();
address2.setAddress("武侯区");
Set<Address> set = new HashSet<Address>();
set.add(address1);
set.add(address2); Customer customer = new Customer();
customer.setCustomerName("zhubajie");
customer.setAdresses(set);
session.save(customer);
ts.commit();
session.close();

多对多,需要第三张表来建立关联关系,必须有一方放弃关联关系维护

类里面两边互相有对方作为成员变量

items:

private Set<Orders> orders=new HashSet<Orders>();

orders:

private Set<Items> items = new HashSet<>();

xml配置里面要设置第三张表来关联:orders_r_items  第三张表

items xml:

<set name="orders" table="orders_r_items">
<key column="itemsId"></key>
<many-to-many class="Orders" column="orderId"></many-to-many>
</set>

orders xml:

<!-- items的集合 多对多,必须有一方放弃关联关系维护 -->
<set name="items" table="orders_r_items" inverse="true">
<key column="orderId"></key>
<many-to-many class="Items" column="itemsId"></many-to-many>
</set>

测试代码:

Session session = HibernateUtil.getSession();
Transaction tx = session.beginTransaction(); Items item = new Items();
item.setPrice(new Double(100));
Items item1 = new Items();
item1.setPrice(new Double(200)); Orders o = new Orders();
o.setCreateTime(new Date());
Orders o1 = new Orders();
o1.setCreateTime(new Date()); o.getItems().add(item);
o.getItems().add(item1); o1.getItems().add(item);
o1.getItems().add(item1); item.getOrders().add(o);
item.getOrders().add(o1); item1.getOrders().add(o);
item1.getOrders().add(o1); session.save(item);
session.save(item1); session.save(o);
session.save(o1); tx.commit();
session.close();

hibernate关系映射的更多相关文章

  1. Hibernate学习笔记-Hibernate关系映射

    1. 初识Hibernate——关系映射 http://blog.csdn.net/laner0515/article/details/12905711 2. Hibernate 笔记8 关系映射1( ...

  2. 【SSH 基础】浅谈Hibernate关系映射(4)

    继上篇博客 多对多关联映射(单向) 多对多对象关系映射,须要增加一张新表完毕基本映射. Hibernate会自己主动生成中间表 Hibernate使用many-to-many标签来表示多对多的关联,多 ...

  3. web进修之—Hibernate 关系映射(3)

    概述 Hibernate的关系映射是Hibernate使用的难点或者是重点(别担心,不考试哦~),按照不同的分类方式可以对这些映射关系做一个分类,如: 按对象对应关系分: 一对一 多对一/一对多 多对 ...

  4. Hibernate关系映射时出现的问题

    在学习Hibernate框架的关系映射时,遇到了一个问题: INFO: HHH000422: Disabling contextual LOB creation as connection was n ...

  5. Hibernate关系映射之many-to-many

    1.建表 2.创建实体类及映射文件 Student.java类 public class Student implements java.io.Serializable { // Fields pri ...

  6. Hibernate关系映射(注解)

    1.类级别注解 @Entity     映射实体类 @Table    映射数句库表 @Entity(name="tableName") - 必须,注解将一个类声明为一个实体bea ...

  7. Hibernate关系映射(三) 多对多

    一.使用用户User和Role实现多对多的示例 User.java,实现对Role的引用 package com.lxit.entity; import java.util.HashSet; impo ...

  8. Hibernate关系映射(三) 多对一和一对多

    一.多对一 学生Student和班级Grade实现多对一,多个学生对应一个班级. Student.java实体类,映射了班级的属性. package com.lxit.entity; import j ...

  9. Hibernate关系映射(二) 基于外键的双向一对一

    基于外键的双向一对一关联映射 需要在一端添加<one-to-one>标签,用property-ref来指定反向属性引用. 还是通过刚才用户和地址来演示双向一对一关联. 代码演示 一.实体类 ...

随机推荐

  1. 关于C语言程序条件编译的简单使用方法

    #include <stdio.h> #include <stdlib.h> #define Mode //如果定义了Mode,那么就执行这个函数 #ifdef Mode vo ...

  2. How to configure ODBC DSN to access local DB2 for Windows

    How to configure ODBC DSN to access local DB2 for Windows MA Genfeng (GuangdongUnitoll Services inco ...

  3. 云技术:负载均衡SLB

    什么是SLB? SLB是Server Load Balance(负载均衡)的简称,XX云计算有限公司提供的负载均衡服务,通过设置虚拟服务IP,将位于同一机房的多台云服务器资源虚拟成一个高性能.高可用的 ...

  4. orale中如何获取当前月份?

    就本人所知,在oracle中,有两种方式可以提取系统的当前月份: 1.使用extract 函数,具体用法看SQL语句: select extract(month from sysdate) as &q ...

  5. LeetCode - 验证二叉搜索树

    给定一个二叉树,判断其是否是一个有效的二叉搜索树. 一个二叉搜索树具有如下特征: 节点的左子树只包含小于当前节点的数. 节点的右子树只包含大于当前节点的数. 所有左子树和右子树自身必须也是二叉搜索树. ...

  6. python snownlp情感分析简易demo

    SnowNLP是国人开发的python类库,可以方便的处理中文文本内容,是受到了TextBlob的启发而写的,由于现在大部分的自然语言处理库基本都是针对英文的,于是写了一个方便处理中文的类库,并且和T ...

  7. solr研磨之游标分页

    普通分页 当需要深度分页的时候,比如查询第10000页数据,每页显示10条,意味着需要提取前10000 x 10 页的数据,并将这100000条数据缓存在内存中,然后在内存中进行排序.最后返回最后10 ...

  8. 3 sum closest

    Given an array S of n integers, find three integers in S such that the sum is closest to a given num ...

  9. 多重影分身——C#中多线程的使用二(争抢共享资源)

    只要服务器承受得了,我们可以开任意个线程同时工作以提高效率,然而 两个线程争抢资源可能导致数据混乱. 例如: public class MyFood { public static int Last ...

  10. Gson序列化问题导致的内存溢出,tip:Background sticky concurrent mark sweep GC freed

    问题原因,如果在json model里面放了非可序列化的对象就会导致这中问题,可序列化的就是那些基础数据类型和集合类型,如果在里面放个Android的Activity或者adapter这类类型字段,变 ...