hibernate中关系映射的配置问题
部门和员工属于一对多的关系
员工的账户属于一对一关系
账户和权限属于多对多关系
department.hbm.xml
1 <hibernate-mapping>
2 <class name="com.demo.first.domain.Department" table="department">
3 <id name="did" column="did">
4 <generator class="native"/>
5 </id>
6 <property name="name" column="name"/>
7 <property name="description" column="description"/>
8 <set name="employeeSet" inverse="true" cascade="save-update">
9 <!-- 外键的名称(字段名):也就是说如果是一对多的关系,那么会在多的一方生成的外键名称是 column 中的值,
10 这个值是可以改变的,建议和对应的名称一致 -->
11 <key column="wj_id"></key>
12 <one-to-many class="com.demo.first.domain.Employee"/>
13 </set>
14 </class>
15 </hibernate-mapping>
employee.hbm.xml
1 <hibernate-mapping>
2 <class name="com.demo.first.domain.Employee" table="employee">
3 <id name="eid" column="eid">
4 <generator class="foreign"><!-- 直接将主键和外键进行关联,主键同时作为外键使用,在 hibernate 中 one-to-one 没办法在代码中体现出新字段名,可以使用many-to-one来生成一个字段,也可以使用此方法来生成外键 -->
5 <param name="property">userAccount</param>
6 </generator>
7 </id>
8 <property name="name" column="name" length="20"/>
9 <property name="gender" column="gender"/>
10 <property name="birthday" column="birthday"/>
11 <property name="description" column="description"/>
12 <one-to-one name="userAccount" class="com.demo.first.domain.UserAccount" constrained="true" cascade="save-update"/>
13 <!-- 和 department 中配置 column 的名称是一样的,需要对应 -->
14 <many-to-one name="department" class="com.demo.first.domain.Department" column="wj_id"/>
15 </class>
16 </hibernate-mapping>
privilege.hbm.xml
1 <hibernate-mapping>
2 <class name="com.demo.first.domain.Privilege" table="privilege">
3 <id name="pid" column="pid">
4 <generator class="native"/>
5 </id>
6 <property name="action"/>
7 <set name="userAccountSet" table="userAccount_privilege">
8 <!-- 和一对多一样的操作,column 是在生成的字段名(外键),是可以改变的,多对多的关系中,会生成一个中间表,那么在
9 column 中配置的参数就是生成的中间表中的字段名,另外一方配置的字段名需相同-->
10 <key column="wj_pid"></key>
11 <many-to-many class="com.demo.first.domain.UserAccount" column="ua_wj_id"/>
12 </set>
13 </class>
14 </hibernate-mapping>
useraccount.hbm.xml
1 <hibernate-mapping>
2 <class name="com.demo.first.domain.UserAccount" table="userAccount">
3 <id name="uaid" column="uaid">
4 <generator class="native"/>
5 </id>
6 <property name="loginName" column="loginName"/>
7 <property name="password" column="password"/>
8 <one-to-one name="employee" class="com.demo.first.domain.Employee"/>
9 <set name="privilegeSet" table="userAccount_privilege">
10 <!-- 对应于另一方的参数配置,column 的参数值和另一方相同,也就是生成的中间表的字段名相同 -->
11 <key column="ua_wj_id"></key>
12 <many-to-many column="wj_pid" class="com.demo.first.domain.Privilege"/>
13 </set>
14 </class>
15 </hibernate-mapping>
另附上可以打开 hibernate debug 模式(可以查看所有的操作,包括自动建表语句等等):
需要的 jar 包等:

hibernate文件下载:https://sourceforge.net/projects/hibernate/files/hibernate-orm/5.4.2.Final/hibernate-release-5.4.2.Final.zip/download
在 hibernate-release-5.4.2.Final\project\etc 中找到 log4j.properties 这个文件,直接放到 src 的根目录下,即可:


重点就是上面的那个语句,去掉注释(默认是打开的,没有注释)重启即可,

2019-04-25
hibernate中关系映射的配置问题的更多相关文章
- hibernate(3) —— 关系映射
hibernate中关系映射指的是实体类与实体类间的关系.和数据库中表与表之间的关系类似,有一对一,多对一,一对多,多对多四种映射关系. 一:一对一映射 两个对象之间是一对一的关系,如人和身份证之间是 ...
- Hibernate中的映射关系(一对多)
在数据库中表和表之间的关系有几种,(一对一,一对多,多对多)一对一关系:可以选择任意一方插入外键(one-to-one:one-to-one<--->many-to-one[unique= ...
- Hibernate注解关系映射
Hibernate Annotation关系映射的几种类型映射用法及使用方法(说明:以前实例的实体是user和role,主键分别是userid和roleid) 1)一对一外键关联映射(单向) @O ...
- hibernate中一对一映射
一.hibernate中一对一映射有两种 1 主键方式,一张表的主键是通过另一张表的主键生成的 2 外键方式,一张表添加外键引用另一张表的主键,并添加唯一unique约束 二.下面进行简单例子,用户和 ...
- hibernate中的映射
hibernate中的映射是指Java类和数据库表中的属性来进行关联,然后通过类来操作数据库中,这就是简单的映射.
- 详谈Hibernate框架关系映射!
接触Hibernate也有一小段的时间了,愈发的觉得Hibernate是个神奇的东西,为什么这么说呢?因为你可以不懂一行sql,直接面向对象,就可以将数据直接保存到数据库去!! 你还可以保存一个对象, ...
- hibernate 实体关系映射笔记
@经常使用属性说明: @Entity:实体类 @Table:指定相应数据表 @Id:主键,使用能够为null值的类型,假设实体类没有保存到数据库是一个暂时状态 @Col ...
- hibernate对象关系映射( 一对一,一对多,多对一,多对多的单向,双向映射 ——)
对象之间的关系: 关系映射之间的关系只的是对象之间的关系,并不指数据库表的关系(外键关系)这儿解决的问题是当对象之间的关系之一时,数据库表该如何映射,编程上如何对待. 一对一(主键关联,和单向的外键关 ...
- Hibernate 对象关系映射文件
简介: POJO 类和关系型数据库之间的映射可以用一个 XML 文档来定义 通过 POJO 类的数据库映射文件,Hibernate 可以理解持久化类和数据表之间的对应关系,也可以理解持久化类属性与数据 ...
随机推荐
- K8S(15)监控实战-ELK收集K8S内应用日志
K8S监控实战-ELK收集K8S内应用日志 目录 K8S监控实战-ELK收集K8S内应用日志 1 收集K8S日志方案 1.1 传统ELk模型缺点: 1.2 K8s容器日志收集模型 2 制作tomcat ...
- Atlas 分表功能
目录 分表原因 分表方式 Atlas 分表 分表思路 配置 Atlas 创建原表 创建分表 数据测试 分表原因 1.数据过多,访问缓慢 2.创建索引时重新排序,创建缓慢,并且占用大量的磁盘空间 分表方 ...
- Shpfile文件的字段类型说明
Shpfile文件的字段类型设置如下表所示: 字段类型 字符 字段长度 长整型 N 9 短整型 N 4 浮点型 F 13 双精度 F 19 文本 C 50 特别需要注意的是字段长度,在导出SHP的时候 ...
- 基于用户的协同过滤的电影推荐算法(tensorflow)
数据集: https://grouplens.org/datasets/movielens/ ml-latest-small 协同过滤算法理论基础 https://blog.csdn.net/u012 ...
- msfconsole web后门
一.PHP后门 在meterpreter中有一个名为PHP meterpreter的payload,利用这个可以成功反弹.步骤如下: 1. 使用msfvenom 创建一个webshell.php 2. ...
- website URL & UTM
website URL & UTM UTM user track message utm_source https://zhuanlan.zhihu.com/p/143473571?utm_s ...
- React & Desktop App
React & Desktop App https://proton-native.js.org/#/ https://github.com/kusti8/proton-native
- django学习-22.admi管理后台页面的文案展示等相关配置
目录结果 1.前言 2.完整的操作步骤 2.1.第一步:对[settings.py]里的相关常量的值做如下修改 2.2.第二步:重启django项目[helloworld]的服务 2.3.第三步:重新 ...
- Linux/UNIX编程如何保证文件落盘
本文转载自Linux/UNIX编程如何保证文件落盘 导语 我们编写程序write数据到文件中时,其实数据不会立马写入磁盘,而是会经过层层缓存.每层缓存都有自己的刷新时机,每层缓存都刷新后才会写入磁盘. ...
- Java基础语法:final修饰符
一.final类 描述: 用'final'修饰的类不能被继承,没有子类. 例如,我们是无法写一个类去继承String类,然后对String类型扩展的,因为API中已经将String类定义为'final ...