SSH——Hibernate初学者之旅(四)
之前我们说到了一对一和一对多关系的几种映射类型,最后只剩下多对多关系的映射。一般来讲,我们会将多对多关系抽出第三张表,转化为一对多关系,但是难免会有一些特殊情况。今天我们就来看看多对多关系的映射。
一、单向多对多
1、实体
一个人可对应多个地址,一个地址也可以对应多个人。
//人
public class Personnn {private int personid;private String name;private int age;//可以设置多个地址private Set addresses=new HashSet();
//地址
public class Addressnn {private int addressid;private String addressdetail;
2、映射关系实现
<hibernate-mapping><class name="com.lavasoft.dx._n_n.Personnn" table="PERSON_nn"><id name="personid"><generator class="identity"/></id><property name="name"/><property name="age"/><!--映射集合属性,join_1ntab是连接表表名--><set name="addresses"table="join_nn"><!--“column="personid"”确定PERSON_1ntab表关联到连接表的外键列名--><key column="personid"/><!--“column="addressid"”关联PERSON_1ntab表的Address1ntab对象的id在连接表中的列名--><many-to-many
column="addressid"class="com.lavasoft.dx._n_n.Addressnn"/></set></class>
</hibernate-mapping>
<hibernate-mapping><class name="com.lavasoft.dx._n_n.Addressnn" table="ADDRESS_nn"><id name="addressid"><generator class="identity"/></id><property name="addressdetail"/></class>
</hibernate-mapping>
二、双向多对多
1、实体
//人
public class Personnn {private int personid;private String name;private int age;//可以设置多个地址private Set addresses=new HashSet();
public class Addressnn {private int addressid;private String addressdetail;private Set persons = new HashSet();
2、映射关系实现
<hibernate-mapping><class name="com.lavasoft.sx._n_n.Personnn_sx" table="PERSON_nn_sx"><id name="personid"><generator class="identity"/></id><property name="name"/><property name="age"/><!--映射集合属性,关联到持久化类--><!--table="join_1ntab_sx"指定了连接表的名字--><set name="addresses"table="join_nn_sx"cascade="all"><!--column="personid"指定连接表中关联当前实体类的列名--><key column="personid" not-null="true"/><!--column="addressid"是连接表中关联本实体的外键--><many-to-many column="addressid"class="com.lavasoft.sx._n_n.Addressnn_sx"/></set></class>
</hibernate-mapping>
<hibernate-mapping><class name="com.lavasoft.sx._n_n.Addressnn_sx"table="ADDRESS_nn_sx"><id name="addressid"><generator class="identity"/></id><property name="addressdetail"/><!--table="join_nn_sx"是双向多对多的连接表--><set name="persons"inverse="true"table="join_nn_sx"><!--column="addressid"是连接表中关联本实体的外键--><key column="addressid"/><many-to-many column="personid"class="com.lavasoft.sx._n_n.Personnn_sx"/></set></class>
</hibernate-mapping>
总结:
至此,我们将hibernate中常用的几种映射关系已经学习了,至于其他的如继承关系等,这里就不在一一赘述了,我们学习不仅仅停留于此,这只是开了一个头,所以,我们还需要结合实际情况,继续深入学习。
SSH——Hibernate初学者之旅(四)相关推荐
- SSH——Hibernate初学者之旅(五)
之前我们学习了hibernate中的映射关系,接下来我们看看hibernate中的缓存机制,在了解缓存机制之前,我们要先了解一下hibernate中对象的几种状态. 一.三种状态 大家都知道,Java ...
- Hibernate初学者教程
Hibernate初学者教程 欢迎来到Hibernate初学者教程.Hibernate是最广泛使用的Java ORM工具之一.大多数应用程序使用关系数据库来存储应用程序信息,在较低级别,我们使用JDB ...
- HALCON学习之旅(四)
HALCON学习之旅(四) 文章目录 HALCON学习之旅(四) 1.如何对区域进行反选,补集,交集,合并操作 2.如何对区域进行填充操作 3.如何根据区域特征过滤区域 4.如何画各种交互ROI图形 ...
- 打怪升级之小白的大数据之旅(四十六)<HDFS各模块的原理>
打怪升级之小白的大数据之旅(四十六) HDFS各模块的原理 上次回顾 上一章,我们学习了HDFS的基本知识以及一些常用的操作,本章,我们对HDFS各模块的原理进行讲解,了解清楚这些,可以更好的辅助我们 ...
- 打怪升级之小白的大数据之旅(四十一)<大数据与Hadoop概述>
打怪升级之小白的大数据之旅(四十) Hadoop概述 上次回顾 好了,经过了java,mysql,jdbc,maven以及Linux和Shell的洗礼,我们终于开始正式进入大数据阶段的知识了,首先我会 ...
- EKP后端/开发/SSH - Hibernate常用操作(public)
最新笔记链接:https://app.yinxiang.com/fx/07a20d68-0a36-4018-be6b-715450c12e87 基础操作请看: SSH - 配置Service→Dao→ ...
- Apache Solr入门教程(初学者之旅)
2019独角兽企业重金招聘Python工程师标准>>> 写在前面:本文涉及solr入门的各方面,请逐行阅读,相信能帮助你对solr有个清晰全面的了解并能简单实用. 在Apache S ...
- Objective-C学习之旅(四)----内存管理2----retain点语法
一.retain属性的主要作用 1.O-C内存管理和点语法 1>OC内存管理正常情况要使用大量的retain和relrese操作 2>点语法可以减少使用retain和release的操作 ...
- hibernate基础(十四):二级缓存
1.二级缓存是SessionFactory级别的缓存. 2.hibernate启动,二级缓存就存在:hibernate关闭,二级缓存就关闭 注:hibernate本身对二级缓存是关闭的,且没有实现二级 ...
最新文章
- IET Cyber-Systems Robotics线上研讨会:聚焦人工智能与机器人前沿
- C#中的is、as及转换
- Docker打包 Asp.Net Core应用,在CentOS上运行
- [Swift]LeetCode246.对称数 $ Strobogrammatic Number
- CentOS7.7安装MySQL5.6并配置环境变量(详细版)
- JMeter使用命令行模式生成HTML测试报告
- python字符串三,删除空白符,对齐函数及判断函数
- LeetCode 109. Convert Sorted List to Binary Search Tree
- MySQL的 配置文件编写
- JWT 教程_1 SpringBoot与JWT整合
- Hibernate-逆向工程
- 修改Mac版Word默认字体的方法
- 施一公:优秀的科学家如何成长?
- matlab的置换,来自CLUSTERGRAM对象的置换向量(MATLAB)
- 正睿OI补题(二分与分治)
- Lenovo system x3500 m5 安装显卡
- 关于 石墨文档客户端 的案例分析
- 电脑键盘部分按键失灵_键盘失灵个别字母不灵怎么处理_电脑键盘个别键没反应如何修复...
- DICOM医学图像处理:AETitle在C-FIND和C-MOVE请求中的设置问题
- Algorithm(算法