hibernate 数据关联一对多
一对多,多对一 (在多的一端存放一的外键)
但是在实体类中不需要创建这个外键
// 在一的一方创建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 数据关联一对多的更多相关文章
- hibernate 数据关联一对多 3.1
一对多,多对一 (在多的一端存放一的外键) 但是在实体类中不需要创建这个外键 // 在一的一方创建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{ ...
随机推荐
- Linux改动hostname的两个办法
假设你想把主机名改为 linux的话.两中方法: 1. # hostname linux 这样改动了以后马上生效.可是重新启动后就没了 2. # vi /etc/sysconfig/network 改 ...
- Android 主线程和子线程通信问题
Android 如今不支持View在子线程中创建及调用其方法.假设要实现子线程内容更新之后.将结果及时反馈到主线程中,该怎样出来呢? 能够在主线程中创建Handler来实现. 这样子线 ...
- ABAP制作密码输入框
[转自 http://blog.csdn.net/saphome/article/details/6956911] 这几天做一个系统维护的程序,需要用户输入用户名和密码登录.可怎样实现输入密码显示星号 ...
- Spring注解式与配置文件式
http://tom-seed.iteye.com/blog/1584632 Spring注解方式bean容器管理 1.通过在配置文件中配置spring组件注入 <context:compone ...
- 【深度学习】ubuntu16.04下安装opencv3.4.0
1.首先安装一些编译工具 # 安装编译工具 sudo apt-get install build-essential # 安装依赖包 sudo apt-get install cmake git li ...
- linux删除文件夹的命令
使用rm -rf 目录名字 命令即可 -r 就是向下递归,不管有多少级目录,一并删除-f 就是直接强行删除,不作任何提示的意思 eg 删除文件夹实例:rm -rf /var/log/httpd/acc ...
- composer 更新国内镜像地址
composer config -g repo.packagist composer https://packagist.phpcomposer.com
- 0417 封装 property、classmethod、staricmethod
一.封装 把一堆东西装在一个容器里 函数和属性装到了一个非全局的命名空间 class A: __N = 123 # 静态变量 def func(self): print(A.__N) # 在类的内部使 ...
- vo优化总结
问题1:位姿估计用的ransac,只用了几个点,如果3d_2d点存在噪声,不行.优化:把这值当做初值,用非线性优化问题2:深度图有误差,深度过近或过远不行,有误差.而特征点往往在物体边缘处,深度测量值 ...
- Spring Cloud2.0之整合Consul作为注册中心
使用Consul来替换Eureka Consul简介 Consul 是一套开源的分布式服务发现和配置管理系统,由 HashiCorp 公司用 Go 语言开发. 它具有很多优点.包括: 基于 raft ...