hibernate 数据关联一对多 3.1
一对多,多对一 (在多的一端存放一的外键)
但是在实体类中不需要创建这个外键
// 在一的一方创建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 数据关联一对多 3.1的更多相关文章
- hibernate 数据关联一对多
一对多,多对一 (在多的一端存放一的外键) 但是在实体类中不需要创建这个外键 // 在一的一方创建Set集合 public class User { private Integer id; priva ...
- hibernate 数据关联多对多 4.1
多对多,必须有一张关系表来维持关系 数据库student,teacher student_teacher 三张表 但是在pojo中只需要建立student和teacher两个类,除非关系表也代表某种业 ...
- hibernate 数据关联一对一 3.2
第一种一对一 person和card,card的id即作为主键,又作为外键 // 各村对方的一个对象 public class Person { private Integer id; privat ...
- hibernate 数据关联多对多
多对多,必须有一张关系表来维持关系 数据库student,teacher student_teacher 三张表 但是在pojo中只需要建立student和teacher两个类,除非关系表也代表某种业 ...
- hibernate 数据关联一对一
第一种一对一 person和card,card的id即作为主键,又作为外键 // 各村对方的一个对象 public class Person { private Integer id; privat ...
- Hibernate之关联映射(一对多和多对一映射,多对多映射)
~~~接着之前的Hibernate框架接着学习(上篇面试过后发现真的需要学习以下框架了,不然又被忽悠让去培训.)~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射: 1.1: ...
- 初识Hibernate之关联映射(二)
上篇我们介绍了关联映射的几种形式,有单向多对一,单向一对多,还有双向一对多.本篇接着介绍有关关联映射的其他几种映射方式,主要有以下几种: 基于外键的单向一对一关联映射 基于主键的单向一对一关联映射 单 ...
- Hibernate 关联关系(一对多)
Hibernate 关联关系(一对多) 1. 什么是关联(association) 1.1 关联指的是类之间的引用关系.如果类A与类B关联,那么被引用的类B将被定义为类A的属性.例如: class B ...
- Hibernate之关联关系(一对多)
今日分享hibernate框架的简单关联关系 一:关联关系简介 1.1 什么是关联关系 关联指的是类之间的引用关系.如果类A与类B关联,那么被引用的类B将被定义为类A的属性. 例如: class B{ ...
随机推荐
- fastDFS同步问题讨论
一.文件同步延迟问题 前面也讲过fastDFS同组内storage server数据是同步的, Storage server中由专门的线程根据binlog进行文件同步.为了最大程度地避免相互影响以及出 ...
- 【玩转Ubuntu】04. Ubuntu上配置git环境
1. 使用PPA安装Git PPA,表示 Personal Package Archives,也就是个人软件包集. 有很多软件因为种种原因,不能进入官方的 Ubuntu 软件仓库. 为了方便 Ubun ...
- Python输出中文乱码问题
//建立一个文件test.txt,文件格式用ANSI,内容为: //abc中文 //用python来读取 # coding=gbk print open("Test.txt").r ...
- ios蓝牙开发(三)app作为外设被连接的实现
再上一节说了app作为central连接peripheral的情况,这一节介绍如何使用app发布一个peripheral,给其他的central连接 还是这张图,central模式用的都是左边的类,而 ...
- ios即时通讯客户端开发之-mac上基于XMPP的聊天客户端开发环境搭建
1.搭建服务器 - 安装顺序 - (mysql->openfire->spark) 数据库:mysql 服务器管理工具: openfire 测试工具: spark mysql 安装 h ...
- Python 3 学习笔记
教程地址: http://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/00143161198 ...
- Unity cg vertex and fragment shaders(一)
cg片段 Cg程序片段写CGPROGRAM和ENDCG之间 开始时的片段可以作为#pragma语句编译指令 Pass { // ... the usual pass state setup ... C ...
- subversion和客户端的应用
1.安装svn的服务器端subversion.以及windows客户端TortoiseSVN: 2 cmd 建立库,名字为svnpro ----- svnadmin create F:\svnpro, ...
- python之math模块
1.math简介 >>>import math #导入math模块 >>>dir(math) #这句可查看所有函数名列表 >>>help(math ...
- linux和windows的文件互传
Linux →→→Windows 1.使用secureCRT:下载文件只需在shell终端仿真器中输入命令"sz 文件名",即可利用Zmodem将文件下载到本地某目录下. 2. s ...