一对多,多对一 (在多的一端存放一的外键)
但是在实体类中不需要创建这个外键

// 在一的一方创建Set集合
public class User { private Integer id;
private String username;
private String password;
private Set<Address> addressSet;
}
//多的一方创建User的对象
public class Address { private Integer id;
private String address;
private User user;
}

在映射文件中也要配置

一对多的一:User.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 package="com.kaishengit.pojo"> <class name="User" table="user">
<id name="id">
<generator class="native"/>
</id> <property name="username"/>
<property name="password"/>
<!-- name是类中属性的名字,站在User的角度这是一对多,所以是one-to-many
然后指定对应的多指的是哪个类.
<key column="userid"/>指维持这种关系的多的这一端(Address)类对应的表中的外键
inverse="true"表示放弃关系维护-->
<set name="addressSet" cascade="delete" inverse="true">
<key column="userid"/>
<one-to-many class="Address"/>
</set> </class>
</hibernate-mapping>

一对多的多:Address.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 package="com.kaishengit.pojo"> <class name="Address" table="address">
<id name="id">
<generator class="native"/>
</id>
<property name="address"/>
<!-- 站在这个角度是多对一many-to-one
name写对应的属性名,class是对应的类 然后指定外键-->
<many-to-one name="user" class="User" column="userid"/> </class> </hibernate-mapping>

--------------------------------------------------------------------------

--------------------------------------------------------------------------

程序的执行

1.添加

//  方式1
User u1 = new User();
u1.setUsername("u1");
u1.setPassword("aaa"); Address a1 = new Address();
a1.setAddress("a1");
a1.setUser(u1); Address a2 = new Address();
a2.setAddress("a2");
a2.setUser(u1); /* 如果是先save的u1,就能拿到u1的id
然后再save a1,a2的时候加入外键中,等于执行了3条sql 如果是先save a1,a2 那么save的结果是没有userid这个外键的
在save了u1之后会再去update他们(因为在address关联User的时候,user是自由态
,当user保存的时候就变成了持久态,User状态发生变化会同步到数据库中,所以address会更新
),等于执行了3条sql还有两条update*/
session.save(u1);
session.save(a1);
session.save(a2); // 所以对于一对多的这种情况,先存1,再存多 // 方式2 User u1 = new User();
u1.setUsername("u1");
u1.setPassword("aaa"); Address a1 = new Address();
a1.setAddress("a1"); Address a2 = new Address();
a2.setAddress("a2"); Set<Address> set = new HashSet<Address>();
set.add(a1);
set.add(a2);
user.setAddressSet(set); // 这样即使是先存1再存多还是5条sql语句 session.save(u1);
session.save(a1);
session.save(a2);

所以在一对多的时候,关系要让多来维护,save的时候先保存一的再保存多的

可以在一的配置中inverse="true"放弃关系维护

2.查询

// 单表查询user
User user = (User) session.get(User.class, 25);
System.out.println(user.getUsername());
/* 要使用address了,单表查询address,这个是延迟查询,当使用address的时候再去查
,但是这个查询就必须放在session中才能有作用,给xxx.hbm.xml配置
lazy="false" 就能取消这个延迟查询,不管你用不用address,但是只要你用user我都会查关联user
的一切比如(address,这个时候就可以放在session外边了因为查询过后已经放入了内存中*/
Set<Address> set = user.getAddressSet();
for(Address a : set) {
System.out.println(a.getAddress());
} // 或者反过来用address查询,也都是两条单表查询
Address a1 = (Address) session.get(Address.class, 17);
System.out.println(a1.getAddress());
System.out.println(a1.getUser().getUsername());

hibernate默认就是这样的单表查询,但是我们可以改成联接查询 -->
<!-- 添加fetch="join"表示用一条sql语句查询到所有包括关联的..所以只要不是
你能承受这么多查询,都要使用以前的延迟查询

<set name="addressSet" cascade="delete" inverse="true" fetch="join">
<key column="userid"/>
<one-to-many class="Address"/>
</set>

3.级联删除

配置属性cascade="delete"属性后,默认删除一的时候把关联的多也删除掉 

<set name="addressSet" cascade="delete" inverse="true">
<key column="userid"/>
<one-to-many class="Address"/>
</set>

也删除了address

User user = (User) session.get(User.class, 26);
session.delete(user);

注:

我们在user中配置了address的Set,在address中配置了user,这叫
双向配置,实际上我们都是从user找address,很少从address找user,所以address的可以不配置

hibernate 数据关联一对多的更多相关文章

  1. hibernate 数据关联一对多 3.1

    一对多,多对一 (在多的一端存放一的外键) 但是在实体类中不需要创建这个外键 // 在一的一方创建Set集合 public class User { private Integer id; priva ...

  2. hibernate 数据关联多对多 4.1

    多对多,必须有一张关系表来维持关系 数据库student,teacher student_teacher 三张表 但是在pojo中只需要建立student和teacher两个类,除非关系表也代表某种业 ...

  3. hibernate 数据关联一对一 3.2

    第一种一对一 person和card,card的id即作为主键,又作为外键  // 各村对方的一个对象 public class Person { private Integer id; privat ...

  4. hibernate 数据关联多对多

    多对多,必须有一张关系表来维持关系 数据库student,teacher student_teacher 三张表 但是在pojo中只需要建立student和teacher两个类,除非关系表也代表某种业 ...

  5. hibernate 数据关联一对一

    第一种一对一 person和card,card的id即作为主键,又作为外键  // 各村对方的一个对象 public class Person { private Integer id; privat ...

  6. Hibernate之关联映射(一对多和多对一映射,多对多映射)

    ~~~接着之前的Hibernate框架接着学习(上篇面试过后发现真的需要学习以下框架了,不然又被忽悠让去培训.)~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射: 1.1: ...

  7. 初识Hibernate之关联映射(二)

    上篇我们介绍了关联映射的几种形式,有单向多对一,单向一对多,还有双向一对多.本篇接着介绍有关关联映射的其他几种映射方式,主要有以下几种: 基于外键的单向一对一关联映射 基于主键的单向一对一关联映射 单 ...

  8. Hibernate 关联关系(一对多)

    Hibernate 关联关系(一对多) 1. 什么是关联(association) 1.1 关联指的是类之间的引用关系.如果类A与类B关联,那么被引用的类B将被定义为类A的属性.例如: class B ...

  9. Hibernate之关联关系(一对多)

    今日分享hibernate框架的简单关联关系 一:关联关系简介 1.1 什么是关联关系 关联指的是类之间的引用关系.如果类A与类B关联,那么被引用的类B将被定义为类A的属性. 例如: class B{ ...

随机推荐

  1. ABAP面试经历【转http://blog.csdn.net/tsj19881202/article/details/8792742】

    本周三面试了一次HP的globe部门,整个过程自己感觉特别糟糕.总结了一下经验, 1.不能把自己平时做的东西,很好的用语言描述出来 2.技术点其实都会,但是不了解对方问题的意思,所以没能很好的回答对方 ...

  2. python 局部local和全局global变量

    global和local变量 虽然简单,但是还是记录一下,主要是转载 转载自:http://blog.sina.com.cn/s/blog_436992740102ux8z.html   先看一段代码 ...

  3. UVALive - 7045 Last Defence 【数学】

    题目链接 https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_ ...

  4. 【leetcode刷题笔记】Reverse Words in a String

    Given an input string, reverse the string word by word. For example,Given s = "the sky is blue& ...

  5. P3988 [SHOI2013]发牌

    题目 P3988 [SHOI2013]发牌 做法 我们切牌时的状态: 手玩几次后我们发现切\(K\)次牌就是求堆顶一下的\(K+1\)大值,套上主席树就好了 My complete code #inc ...

  6. 常用CSS设置

    主要内容: 一.容器类 二.文本类 三.特效类 一.容器类 1.background-image:url('img/02.gif');   设置背景图(可以是动态图) 2.background-col ...

  7. Docker-端口映射与容器互联

    在使用docker过程中,通常会碰到需要多个服务组件容器共同协作的情况,这往往需要多个容器之间有能够互相访问到对方的服务除了通过网络访问外,Docker还提供了两个很方便的功能来满足服务访问的基本需求 ...

  8. Spark- Spark基本工作原理

    Spark特点: 1.分布式 spark读取数据时是把数据分布式存储到各个节点内存中 2.主要基于内存(少数情况基于磁盘,如shuffle阶段) 所有计算操作,都是针对多个节点上内存的数据,进行并行操 ...

  9. JQuery 常用代码

    1.选择器 1.根据标签名: $('p')  选择文档中的所有段落    2. 根据ID: $("#some-id")    3.类: $('.some-class') $('.t ...

  10. js 定义hash类

    // JavaScript Documentfunction HashTable(){    this._hash={};    this._count=0;            /**    *添 ...