【Hibernate框架】关联映射(多对多关联映射)
按着我们的总结行进计划,接下来,就是有关于多对多映射的总结了。
我们来举个例子啊,很长时间以来,房价暴涨不落,但是还有很多人拥有很多套房产,假如说,一个富豪拥有九套房产,家里人么准去住哪一套,我们就以说:
对于富豪家人来说:一个人可以拥有很多住址Address;对于房子来说:一套房子可以让很多人住。
1、多对多单向关联映射:
Po对象:Person.Java:
- public class Person
- {
- private int id;
- private String name;
- private Set<Address> address;
- //getter\setter
- }
Address.java
- public class Address
- {
- private int id;
- private String name;
- }
映射文件:Person.hbm.xml
- <hibernate-mapping package="org.hibernate.test">
- <class name="com.ssh.hibernate.Person" table="t_person">
- <id name="id">
- <generator class="native"/>
- </id>
- <set name="addres" table="t_personAddress">
- <key column="personid"/>
- <many-to-many column="addressId" class="com.ssh.hibernate.Address"/>
- </set>
- </class>
- </hibernate-mapping>
Address.hbm.xml:
- <hibernate-mapping package="org.hibernate.test">
- <class name="com.ssh.hibernate.Address" table="t_address">
- <id name="id">
- <generator class="native" />
- </id>
- <property name="name" />
- </class>
- </hibernate-mapping>
运行程序,生成表语句:
- create table Person ( id bigint not null, name varchar(255), primary key(id) )
- create table PersonAddress ( personid bigint not null, addressid bigint not null, primary key (personid, addressid) )
- create table Address ( id bigint not null,name varchar(255), primary key(id) )
测试:
- session.beginTransaction();
- Address address1=new Address();
- address1.setName("<span margin: 0px; padding: 0px; border: currentColor; color: black; background-color: inherit;">font-family: Arial, Helvetica, sans-serif;">唐人街5号</span>");
- session.save(address1);
- Address address2=new Address();
- address2.setName("北京帽儿胡同12号");
- session.save(address2);
- Address address3=new Address();
- address3.setName("南京花雨石大街10号");
- session.save(course3);
- Address address4=new Address();
- address4.setName("长安大街11号");
- session.save(address4);
- Person person1=new Person();
- Set addres1=new HashSet();
- addres1.add(address1);
- addres1.add(address2);
- person1.setAddresss(addres1);
- person1.setName("赵钱孙");
- session.save(person1);
- Person person2=new Person();
- Set addres2=new HashSet();
- addres2.add(address2);
- addres2.add(address4);
- person2.setAddresss(addres2);
- person2.setName("甲乙丙");
- session.save(person2);
- session.getTransaction().commit();
执行完成后,进行查询测试:
- session.beginTransaction();
- Person person=(Person)session.load(person.class, 1);
- System.out.println(person.getName());
- for(Address s:person.getaddres()){
- System.out.println(s.getName());
- }
- session.getTransaction().commit();
执行查询结果:
- 赵钱孙
- 唐人街5号
- 北京帽儿胡同12号
2、多对多双向关联映射:
Po对象:Person.java:
- public class Person
- {
- private int id;
- private String name;
- private Set<Address> address;
- //getter\setter
- }
Address.java
- public class Address
- {
- private int id;
- private String name;
- private Set<Person> person;
- }
配置文件:Person.hbm.xml
- <class name="com.ssh.hibernate.Person" talbe="t_person">
- <id name="id" column="id">
- <generator class="native"/>
- </id>
- <set name="addres" table="t_personAddress">
- <key column="personId"/>
- <many-to-many column="addressId" class="com.ssh.hibernate.Address"/>
- </set>
- </class>
Address.hbm.xml
- <class name="com.ssh.hibernate.Address" table="t_address">
- <id name="id" column="id">
- <generator class="native"/>
- </id>
- <set name="people" inverse="true" table="t_personAddress">
- <key column="addressId"/>
- <many-to-many column="personId" class="com.ssh.hibernate.Person"/>
- </set>
- </class>
这就是双向的了,通过住户可以知道他的所有房产,也可以通过房产知道它的所有的住户。其中值得一说的是<set>的<inverse="true">,还记得咱们的IOC容器的全称吗?Inverse Of Control,控制反转,这里指的也是反转,在多对多关联中,如果设置了inverse="true"就表示本方不进行关联的维护,由另一方进行关联的维护。就那上面实力来说,因为设置了<inverse="true">,所以即使执行:
- Set<Address> adres=new HashSet<Address>();
- adres.add(new Address("北京胡同"));
- adres.add(new Address("南京胡同"));
- person.setAdres(adres);
- session.save(person);
也只会想t_person表中插入数据,而不会向t_personAddress表中插入数据,如果想要同时插入数据,只需要将inserve设置为false;在多对多双向关联映射中,任何一方设置inserve=true都可以,没有特殊限定,因为两方都一样。
【Hibernate框架】关联映射(多对多关联映射)的更多相关文章
- Hibernate框架之双向多对多关系映射
昨天跟大家分享了Hibernate中单向的一对多.单向多对一.双向一对多的映射关系,今天跟大家分享下在Hibernate中双向的多对多的映射关系 这次我们以项目和员工举个栗子,因为大家可以想象得到,在 ...
- (Hibernate进阶)Hibernate映射——多对多关联映射(八)
多对多映射是现实生活中最常见的映射,也是最容易理解的映射.废话少说,直接开始. 映射原理 不论是单向关联还是双向关联都是通过第三张表,将两个表中的主键放到第三张做一个关联.用第三张表来解决可能会造成数 ...
- Hibernate(六)——多对多关联映射
前面几篇文章已经较讲解了三大种关联映射,多对多映射就非常简单了,不过出于对关联映射完整性的考虑,本文还是会简要介绍下多对多关联映射. 1.单向多对多关联映射 情景:一个用户可以有多个角色,比如数据录入 ...
- 一口一口吃掉Hibernate(六)——多对多关联映射
今天来说说hibernate中的多对多关联映射,多对多关联映射涉及到单向映射和双向映射2种. 首先举个多对多关联例子:用户User和角色Role,一个用户可以属于多个角色,一个角色可以有多个用户.这就 ...
- 【SSH系列】Hibernate映射 -- 多对多关联映射
映射原理 在数据库学习阶段,我们知道,如果实体和实体之间的关系是多对多,那么我们就抽出来第三张表,第一张表和第二张表的主键作为第三表的联合主键,结合我们的hibernate,多对多关联,无论 ...
- 【SSH进阶之路】Hibernate映射——多对多关联映射(八)
上篇博文[SSH进阶之路]Hibernate映射——一对多关联映射(七),我们介绍了一对多关联映射,它是多对多关联映射的基础. 多对多映射是现实生活中最常见的映射,也是最容易理解的映射.废话少说,直接 ...
- java之hibernate之单向的多对多关联映射
这篇 单向的多对多关联映射 1.如何在权限管理中,角色和权限之间的关系就是多对多的关系,表结构为: 2.类结构 Permission.java public class Permission impl ...
- java之hibernate之双向的多对一关联映射
这篇讲解 双向的多对一关联映射 1.表结构和多对一时,一致 2.类结构 Book.java public class Book implements Serializable{ private int ...
- Hibernate—— 一对多 和 多对多关联关系映射(xml和注解)总结(转载)
One to Many 映射关系 多对一单向外键关联(XML/Annotation) 一对多单向外键关联(XML/Annotation) 懒加载和积极加载 一对多双向外键关联(XML/Annotati ...
- Hibernate一对多自关联、多对多关联
今天分享hibernate框架的两个关联关系 多对多关系注意事项 一定要定义一个主控方 多对多删除 主控方直接删除 被控方先通过主控方解除多对多关系,再删除被控方 禁用级联删除 关联关系编辑,不 ...
随机推荐
- jQuery的选择器中的通配符[id^='code'] 等示例及说明
1.选择器 (1)通配符: $("input[id^='code']");//id属性以code开始的所有input标签 $("input[id$='code']&quo ...
- 美团HD(1)-设置导航栏主题
自定义一个UINavigationController DJNavigationController.h #import <UIKit/UIKit.h> @interface DJNavi ...
- MFC下打开选择文件夹并获取文件夹的绝对路径
http://blog.csdn.net/w18758879921/article/details/51613382 http://www.cnblogs.com/greatverve/archive ...
- 【译文】JNI编程
原文链接: https://www3.ntu.edu.sg/home/ehchua/programming/java/JavaNativeInterface.html 没有逐字翻译,解说了文章的大 ...
- Redis-3.2.6 配置文件中文翻译
############## # 指定配置文件: ################################## INCLUDES ############################### ...
- C和指针 第十七章 二叉树删除节点
二叉树的节点删除分为三种情况: 1.删除的节点没有子节点,直接删除即可 2. 删除的节点有一个子节点,直接用子节点替换既可以 3.删除的节点有两个子节点. 对于第三种情况,一般是不删除这个节点,而是删 ...
- C和指针 第十六章 习题
16.8 计算平均年龄 #include <stdlib.h> #include <stdio.h> #define MAX_LEN 512 int main() { int ...
- 数据库操作,jdbc的CRUD
用Java代码操作数据库,可以用JDBC.首先要加载驱动,之后建立连接,再然后就可以对数据库进行操作. 1.建立连接.此处用的是MySQL数据库 public class DBUtil { publi ...
- 域名管理系统DNS
域名系统DNS,将域名转化为ip地址.域名到ip地址解析过程是以这种方式进行的,当某一程序需要把主机名解析为IP地址时,该应用进程就调用解析程序(本地程序),这时候该进程就变成了DNS的一个客户,将待 ...
- Oracle客户端工具出现“Cannot access NLS data files or invalid environment specified”错误的解决办法
Oracle客户端工具出现"Cannot access NLS data files or invalid environment specified"错误的解决办法 方法一:参考 ...