hibernate多表操作实例代码

 更新时间:2018年02月09日 10:25:06   作者:Marksinoberg  
这篇文章主要介绍了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>

总结

配置完以上几步,我们就可以正常的编写我们的“DAO”层代码了,但是由于有了Hibernate的Session这个神器,我们需要做的也就是在DAO层中进行相关的API的调用。这将是非常非常的简单以及轻松的一项任务。

以上就是本文关于hibernate多表操作实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

相关文章

  • Netty中最简单的粘包解析方法分享

    Netty中最简单的粘包解析方法分享

    黏包 是指网络上有多条数据发送给服务端, 但是由于某种原因这些数据在被接受的时候进行了重新组合,本文分享了一种最简单的黏包解析方法, 非常适用于初初初级选手
    2023-05-05
  • 详解springboot项目启动时如何排除用不到的bean

    详解springboot项目启动时如何排除用不到的bean

    使用springboot开发项目,我们有时候会排除一些项目里面用不到的bean,不然的话项目启动会报错,这种情况通常是发生在什么场景里呢,以及如何解决呢,今天咱们就聊一聊
    2024-01-01
  • springboot+websocket+redis搭建的实现

    springboot+websocket+redis搭建的实现

    这篇文章主要介绍了springboot+websocket+redis搭建的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • Java小程序求圆的周长和面积实例

    Java小程序求圆的周长和面积实例

    这篇文章主要介绍了首先用蒙塔卡洛算法求圆周率近似值,然后根据此近似值输出圆的周长和面积,具有一定参考价值,需要的朋友可以了解下。
    2017-09-09
  • MyBatis核心配置文件深入分析

    MyBatis核心配置文件深入分析

    这篇文章主要介绍了MyBatis核心配置文件,MyBatis的前身就是iBatis,iBatis本是由Clinton Begin开发,后来捐给Apache基金会,成立了iBatis开源项目。2010年5月该项目由Apahce基金会迁移到了Google Code,并且改名为MyBatis
    2022-12-12
  • 利用POI读取word、Excel文件的最佳实践教程

    利用POI读取word、Excel文件的最佳实践教程

    Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能。 下面这篇文章主要给大家介绍了关于利用POI读取word、Excel文件的最佳实践的相关资料,需要的朋友可以参考下。
    2017-11-11
  • springboot如何查找配置文件路径的顺序和其优先级别

    springboot如何查找配置文件路径的顺序和其优先级别

    此文是在工作中遇到的关于springboot配置文件的问题,在网上查阅资料和自己测试之后记录的,以便日后查阅。希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • SpringCloud学习笔记之SpringCloud搭建父工程的过程图解

    SpringCloud学习笔记之SpringCloud搭建父工程的过程图解

    SpringCloud是分布式微服务架构的一站式解决方案,十多种微服务架构落地技术的集合体,俗称微服务全家桶,这篇文章主要介绍了SpringCloud学习笔记(一)搭建父工程,需要的朋友可以参考下
    2021-10-10
  • SpringCloud微服务多应用脚手架的搭建与部署方式

    SpringCloud微服务多应用脚手架的搭建与部署方式

    这篇文章主要介绍了SpringCloud微服务多应用脚手架的搭建与部署方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • java 二维数组矩阵乘法的实现方法

    java 二维数组矩阵乘法的实现方法

    java 二维数组矩阵乘法的实现方法,需要的朋友可以参考一下
    2013-03-03

最新评论