Hibernate —— Entity.hbm.xml
一、简述
1.对象关系映射文件,用于映射实体类和关系数据库数据表之间的一个 xml 文件。
2.通过 Entity.hbm.xml 映射文件,Hibernate 可以理解持久化类和数据表之间的对应关系,也可以理解持久化类属性与数据表列之间的对应关系。
3.映射主键、映射关联关系。
二、各个节点
<hibernate-mapping>
<class>
<id></id>
<property name=""></property>
<many-to-one name=""></many-to-one>
<one-to-one name=""></one-to-one>
<set name="">
<key></key>
<one-to-many></one-to-many>
<many-to-many></many-to-many>
</set>
<subclass></subclass>
<joined-subclass>
<key></key>
</joined-subclass>
<component name=""></component>
<any id-type="" name="">
<column name=""></column>
<column name=""></column>
</any>
</class>
</hibernate-mapping>
说明:在一个 Entity.hbm.xml 可以定义多个 class 节点,但是通常情况下只定义一个。
1.<hibernate-mapping>
(1)package
如果 hibernate-mapping 节点内存在多个 class 节点,可以通过这个属性来简化开发。相当于一个命名空间。
单个 class 节点的情况下:
<hibernate-mapping >
<class name="com.nucsoft.hibernate.News" table="news" schema="hibernate">
</class>
</hibernate-mapping>
多个 class 节点的情况下:
<hibernate-mapping package="com.nucsoft.hibernate">
<class name="News" table="news" schema="hibernate">
</class>
<class name="Users" table="users" schema="hibernate">
</class>
</hibernate-mapping>
2.<class>
(1)name:类名,如 com.nucsoft.hibernate.News。
(2)table:表明,如 news。类名和表名不一定一致。
(3)schema:库名。如 hibernate 。
(4)dynamic-insert:动态插入。默认为 false。若设置为 true,表示当插入一个对象时,会动态生成 insert 语句,insert 语句仅包含所有取值不为 null 的字段。
①默认
@Test
public void testDynamicInsert() {
News news = new News("bb", null, new java.util.Date());
session.save(news);
}
控制台打印:
Hibernate:
insert
into
hibernate.news
(title, author, date)
values
(?, ?, ?)
②设置 dynamic-insert="true"
@Test
public void testDynamicInsert() {
News news = new News("cc", null, new java.util.Date());
session.save(news);
}
控制台打印:
Hibernate:
insert
into
hibernate.news
(title, date)
values
(?, ?)
注意:设置为 null 的字段不存在 非空约束。
(5)dynamic-update:动态更新。默认为 false。若设置为 true,表示当更新一个对象时,会动态生成 update 语句,update 语句中仅包含所有取值需要更新的字段。
①默认
@Test
public void testDynamicUpdate() {
News news = (News) session.get(News.class, 205);
news.setAuthor("BB");
}
控制台打印:
Hibernate:
update
hibernate.news
set
title=?,
author=?,
date=?
where
id=?
②设置 dynamic-update="true"
@Test
public void testDynamicUpdate() {
News news = (News) session.get(News.class, 206);
news.setAuthor("CC");
}
控制台打印:
Hibernate:
update
hibernate.news
set
author=?
where
id=?
(6)select-before-update:设置某个持久化对象在更新前是否执行一次查询。如,对一个游离对象的更新,再更新前先查询使游离对象变为持久化对象,
若该对象和数据库中对应记录状态一致,则不再发送 UPDATE 语句。但是会影响性能。
3.<id>
说明:
- Hibernate 通过 OID 来建立内存中的对象和数据表中记录的对应关系。对象的 OID 和数据表的主键对应。Hibernate 通过标识符生成器来为主键赋值。
- Hibernate 推荐在数据表中使用代理主键,即不具备任何业务含义的字段。代理主键通常为整型。
- <id> 节点用来设置对象标识符,<generator> 子元素用来设定标识符生成器。Hibernate 提供了标识符生成器接口:IdentifierGenerator,提供了内置的实现,我们也可以通过实现这个接口来定义我们自己的生成器。
(1)name:持久化类的属性名。
(2)column:对应数据表的列名。
(3)type:Hibernate 的映射类型。
(4)unsaved-value:如果存在一个对象的 id 和 unsaved-value 值相同,会被认为成一个临时对象。
(4)子节点:<generator>。为持久化类设定标识符生成器。
- class 属性,生成器的全限定类名或缩写。一般使用缩写。
- increment:会存在并发问题,会出现主键重复。只适用于测试。
- hilo:在Hibernate 4.2.2 版本中,已过时。org.hibernate.id.enhanced.SequenceStyleGenerator 替代了它。
4.<property>
(1)name:指定该持久化类的属性名称。
(2)type:Hibernate 映射类型。(Hibernate 映射类型,是 Java 类型和 SQL 类型的桥梁)
(3)column:指定映射的表的字段名,可以定义为子节点的形式。
(4)access:指定 Hibernate 的默认的属性访问策略。默认为 property,即使用 getter/setter。若指定 field,则通过反射来访问成员变量。
(5)unique:是否添加一个唯一约束。
(6)update:这一列的值是否可以被修改。
(7)index:指定一个索引名称。
(8)scale:指定该属性所映射数据列的小数位。对 double/float/decimal 等有效。
(9)formula:设置一个 Sql 表达式,Hibernate 将根据它来计算出派生属性的值。
注意:
- 派生属性:并不是持久化类的所有属性都直接和表的字段匹配,持久化类的有些属性的值必须在运行时才能计算出来。
- formula="(sql)" 括号不能少。
- sql 语句中的列名和表名应与数据库中的列名和表名对应,而不是和持久化类名和属性名对应。
e:在 News 中添加了 String 类型的 desc 字段。
News.hbm.xml 配置:
<property name="desc" formula="(SELECT concat(title, ': ', author) FROM news n WHERE n.id = id)"/>
测试:
@Test
public void testFormula() {
News news = (News) session.get(News.class, 1);
System.out.println(news.getDesc());
}
控制台打印:
Hibernate:
select
news0_.id as id1_0_0_,
news0_.title as title2_0_0_,
news0_.author as author3_0_0_,
news0_.date as date4_0_0_,
(SELECT
concat(news0_.title,
': ',
news0_.author)
FROM
news n
WHERE
n.id = news0_.id) as formula0_0_
from
hibernate.news news0_
where
news0_.id=?
dd: DD
可以发现,是以子查询的方式来设置派生属性的。
三、映射时间、日期类型
1.基础知识
(1)在 Java 中,代表日期和时间的类型有:java.util.Date 和 java.util.Calendar。此外,JDBC 提供了 3 个扩展:java.sql.Date、java.sql.Time、java.sql.Timestamp。
分别和标准 SQL 的 date 、time、timestamp 类型对应。
(2)在标准 SQL 中,DATE 类型表示日期,TIME 类型表示时间,TIMESTAMP 类型表示时间戳,同时包含日期和时间信息。
(3)因为 java.util.Date 是 java.sql.Date,java.sql.Time 和 java.sql.Timestamp 的父类,所以 java.util.Date 可以对应标准 SQL 的Date、Time、Timestamp 类型。
基于上述所说,可以将实体类的 Date 类型设置为 java.util.Date 类型。
(4)如何将 java.util.Date 映射为 Date,Time,Timestamp?
①在 Eclipse 下,是根据实体和映射文件去生成数据表。
可以通过 property 的 type 属性来进行映射。
例如:
<property name="date" type="timestamp">
<column name="DATE" />
</property> <property name="date" type="data">
<column name="DATE" />
</property> <property name="date" type="time">
<column name="DATE" />
</property>
其中 timestamp, date, time 既不是 Java 类型, 也不是标准 SQL 类型, 而是 hibernate 映射类型。
②在 Intellij Idea 下,是根据表去生成 Entity.hbm.xml 和实体类。
生成的实体日期类型为具体的 java.sql.date 或 java.sql.time 或 java.sql.timestamp。
这里需要对其更改为其父类:java.util.date。
经过测试发现,对应 property 的 type 属性写与不写都不会影响最终结果。如:
<property name="birthday">
<column name="birthday" sql-type="timestamp"/>
</property>
插入的结果也是带有日期和时间的时间戳。
③小结:在 Eclipse 下,必须要显式的指定 property 的 type 属性,来进行日期时间的精确映射。而在 Intellij Idea 下,需要将实体类的日期和时间类型改为 java.util.Date 类型。
(5)Java 类型、Hibernate 类型、标准 SQL 类型对应表
四、关于 Blob,Clob 这里不进行说明。在项目中处理二进制和大数据类型的对象很少通过 Blob和 Clob进行存储。
五、总结
介绍了实体类和数据表是如何映射的,主键是怎么生成的,是怎么映射的,属性和列是怎么映射的。也介绍了日期时间的映射。
Hibernate —— Entity.hbm.xml的更多相关文章
- hibernate中.hbm.xml和注解方式自动生成数据表的简单实例(由新手小白编写,仅适用新手小白)
绝逼新手小白,so 请大神指点! 如果真的错的太多,错的太离谱,错的误导了其他小伙伴,还望大神请勿喷,大神请担待,大神请高抬贵嘴......谢谢. 好了,正题 刚接触ssh,今天在搞使用.hbm.xm ...
- hibernate 关于hbm.xml编写的总结
在Hibernate中,各表的映射文件….hbm.xml可以通过工具生成,例如在使用MyEclipse开发时,它提供了自动生成映射文件的工具.本节简单的讲述一下这些配置文件的配置. 配置文件的基本结构 ...
- hibernate的.hbm.xml文件文件配置属性详解
一般.hbm.xml文件如下面: <?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "- ...
- hibernate(*.hbm.xml)中新添加的字段被标记为红色(找不到)的解决方法
首先得是以这个方式生成的bean和xml,配置好了数据源(这样才能让hibernate中的配置和mysql进行交互) https://www.cnblogs.com/kinome/p/10549969 ...
- Hibernate XXX.hbm.xml 里的class标签的 schema 属性解释
转自:https://blog.csdn.net/mym43210/article/details/30230173 1 <?xml version="1.0" encodi ...
- hibernate之.hbm.xml文件内容相关参数说明
1.<id> 表示主键,下面介绍主键的生成机制 Increment: 由hibernate自动以递增的方式生成表识符,每次增量为1 Identity:由底层数据库生成表识符.条件是数据库支 ...
- Hibernate JavaBean.hbm.xml配置
主键生成策略: hibernate中必须设置主键 <generator> 由数据库维护: identity:用于自动生成主键方式(没有自增主键的数据库不使用eg:oracle) seque ...
- Hibernate 的*.hbm.xml文件的填写技巧
================================================================================= 模板: <!-- ?属性,本类 ...
- 【转载】Hibernate之hbm.xml集合映射的使用(Set集合映射,list集合映射,Map集合映射)
https://www.cnblogs.com/biehongli/p/6555994.html
随机推荐
- JavaScript编码规范
1 代码风格 1.1 结构语句 [强制] 不得省略语句结束的分号. [强制] 在 if / else / for / do / while 语句中,即使只有一行,也不得省略块 {...}. 示例: / ...
- SQL Server恢复软件 Stellar Phoenix sql recovery
SQL Server恢复软件 Stellar Phoenix sql recovery http://www.stellarinfo.com/ http://www.stellarinfo.com/ ...
- RPC 的概念模型与实现解析
今天分布式应用.云计算.微服务大行其道,作为其技术基石之一的 RPC 你了解多少?一篇 RPC 的技术总结文章,数了下 5k+ 字,略长,可能也不适合休闲的碎片化时间阅读,可以先收藏抽空再细读:) 全 ...
- Linux 部署ASP.NET SQLite 应用 的坎坷之旅 附demo及源码
Linux 部署ASP.NET SQLite 应用 的坎坷之旅.文章底部 附示例代码. 有一台闲置的Linux VPS,尝试着部署一下.NET 程序,结果就踏上了坑之路,不过最后算是完美解决问题,遂记 ...
- .NET开发笔记(二十三) 谷歌地图下载
关于如何将地球经纬度坐标系统转换成程序中常用到的平面2D坐标系统,网上的文章很多,参考http://www.cnblogs.com/beniao/archive/2010/04/18/1714544. ...
- [.net 面向对象程序设计深入](5)MVC 6 —— 构建跨平台.NET开发环境(Windows/Mac OS X/Linux)
[.net 面向对象程序设计深入](5)MVC 6 —— 构建跨平台.NET开发环境(Windows/Mac OS X/Linux) 1.关于跨平台 上篇中介绍了MVC的发展历程,说到ASP.NET ...
- [LeetCode] Interleaving String - 交织的字符串
题目如下:https://oj.leetcode.com/problems/interleaving-string/ Given s1, s2, s3, find whether s3 is form ...
- [异常解决] ubuntu上安装JLink驱动遇到的坑及给后来者的建议
一.前言 最近将整个电脑格式化,改成了linux操作系统 希望这样能让自己在一个新的世界探索技术.提升自己吧- win上的工具用多了,就不想变化了- 继上一篇<ubuntu上安装虚拟机遇到的问题 ...
- Redis应用场景一
Redis开创了一种新的数据存储思路,使用Redis,我们不用在面对功能单调的数据库时,把精力放在如何把大象放进冰箱这样的问题上,而是利用Redis灵活多变的数据结构和数据操作,为不同的大象构建不同的 ...
- Angular1还是Angular2
Angular1还是Angular2 学完angular1,尝试去看了下angular2,虽然号称更强更快,可是这基于ES6和TypeScript的全新框架让人完全招架不住,而且我只是需要angula ...