这篇文章将为大家详细讲解有关hibernate如何实现多表操作,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
思路就是:
在数据库底层通过添加中间表来指定关联关系。
在双方的实体中添加一个保存对方的集合
在双方的配置文件中使用set标签和many-to-many标签来进行关联关系的配置。即可完成!
调用Hibernate的相关的API,操作就行了。
首先是数据库中表的创建
这里有一个小例子:
多对多的核心表,第三方表。table:
create table thrid(
one_id int not null,
two_id int not null,
constranit FK_one_id froeign key(one_id) reference one(id_in_one),
constraint FK_two_id foreign key(two_id) reference two(id_in_two)
);
这里就是将两个表的主键作为了这个第三方的外键了。这样可以方便关系的搭建。
然后是创建核心的Hibernate.cfg.cml文件,这里不再过多的阐述。
再就是创建相应的符合数据库中表结构的JavaBean实体类。
遵守JavaBean的命名规范
有无参的构造方法
属性私有,以共有的setter和getter访问
一定一定要记得包含多表中对方的一个集合set。
创建XX.hbm.xml映射文件:
这个映射文件可谓是Hibernate的核心所在了。注意这个文件要放到和实体类一个目录下,也就是放到实体包中,这样会比较好,方便查找和操作。
使用插件生成或者参照模板进行修改。最核心的就是set标签及内部的many-to-many标签了,如下:
employees 映射文件配置(多)
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.itcast.h_hbm_oneToMany">
<class name="Employee" table="employee">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<!-- department属性,Department类型,表示Employee与Department的多对一 -->
<many-to-one name="department" column="departmentId" class="Department"></many-to-one>
</class>
</hibernate-mapping>
以及 department 映射文件配
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="cn.itcast.h_hbm_oneToMany">
<class name="Department" table="department">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<!-- employees属性,Set集合,表达的是Department与Employee的一对多
inverse属性:true表示自己是否放弃维护关联关系,默认为false。
-->
<set name="employees" inverse="true">
<key column="departmentId"></key>
<one-to-many class="Employee"/>
</set>
</class>
</hibernate-mapping>
关于“hibernate如何实现多表操作”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。