hibernate 对象关系映射文件详解

POJO 类和数据库的映射文件*.hbm.xml

  • POJO类和关系数据库之间的映射可以用一个XML文档来定义。
  • 映射文件的扩展名为.hbm.xml
  • 在运行时Hibernate将根据这个映射文件来生成各种SQL语句
  • 通过POJO类的数据库映射文件,Hibernate可以理解持久化类和数据表之间的对应关系,也可以理解持久化类属性与数据库表列之间的对应关系

映射文件说明
hibernate-mapping

类层次:class

  • 主键:id
  • 基本类型:property
  • 实体引用类: many-to-one | one-to-one
  • 集合:set | list | map | array
one-to-many
many-to-many

  • 子类:subclass | joined-subclass
  • 其它:component | any 等
查询语句:query(用来放置查询语句,便于对数据库查询的统一管理和优化)

每个Hibernate-mapping中可以同时定义多个类. 但更推荐为每个类都创建一个单独的映射文件


hibernate-mapping
hibernate 对象关系映射文件详解_第1张图片

hibernate 对象关系映射文件详解_第2张图片


class

hibernate 对象关系映射文件详解_第3张图片

hibernate 对象关系映射文件详解_第4张图片


映射对象标识符

  • Hibernate 使用对象标识符(OID) 来建立内存中的对象和数据库表中记录的对应关系. 对象的 OID 和数据表的主键对应. Hibernate 通过标识符生成器来为主键赋值
  • Hibernate 推荐在数据表中使用代理主键, 即不具备业务含义的字段. 代理主键通常为整数类型, 因为整数类型比字符串类型要节省更多的数据库空间.
  • 在对象-关系映射文件中, <id> 元素用来设置对象标识符. <generator> 子元素用来设定标识符生成器.
  • Hibernate 提供了标识符生成器接口: IdentifierGenerator, 并提供了各种内置实现

id

hibernate 对象关系映射文件详解_第5张图片

hibernate 对象关系映射文件详解_第6张图片


generator




主键生成策略generator

Hibernate提供的内置标识符生成器:
hibernate 对象关系映射文件详解_第7张图片


increment 标识符生成器

increment 标识符生成器由 Hibernate 以递增的方式为代理主键赋值
Hibernate 会先读取 NEWS 表中的主键的最大值, 而接下来向 NEWS 表中插入记录时, 就在 max(id) 的基础上递增, 增量为 1.
适用范围:

  • 由于 increment 生存标识符机制不依赖于底层数据库系统, 因此它适合所有的数据库系统
  • 适用于只有单个 Hibernate 应用进程访问同一个数据库的场合, 在集群环境下不推荐使用它,仅用于测试的开发环境,仅适用于单进程开发环境
  • OID 必须为 long, int 或 short 类型, 如果把 OID 定义为 byte 类型, 在运行时会抛出异常

identity 标识符生成器
identity 标识符生成器由底层数据库来负责生成标识符, 它要求底层数据库把主键定义为自动增长字段类型
适用范围:
  • 由于 identity 生成标识符的机制依赖于底层数据库系统, 因此, 要求底层数据库系统必须支持自动增长字段类型. 支持自动增长字段类型的数据库包括: DB2, Mysql, MSSQLServer, Sybase 等
  • OID 必须为 long, int 或 short 类型, 如果把 OID 定义为 byte 类型, 在运行时会抛出异常

sequence 标识符生成器
sequence 标识符生成器利用底层数据库提供的序列来生成标识符.
hibernate 对象关系映射文件详解_第8张图片
Hibernate 在持久化一个 News 对象时, 先从底层数据库的 news_seq 序列中获得一个唯一的标识号, 再把它作为主键值
适用范围:
  • 由于 sequence 生成标识符的机制依赖于底层数据库系统的序列, 因此, 要求底层数据库系统必须支持序列. 支持序列的数据库包括: DB2, Oracle 等
  • OID 必须为 long, int 或 short 类型, 如果把 OID 定义为 byte 类型, 在运行时会抛出异常

hilo 标识符生成器
hilo 标识符生成器由 Hibernate 按照一种 high/low 算法*生成标识符, 它从数据库的特定表的字段中获取 high 值.
hibernate 对象关系映射文件详解_第9张图片
Hibernate 在持久化一个 News 对象时, 由 Hibernate 负责生成主键值. hilo 标识符生成器在生成标识符时, 需要读取并修改 HI_TABLE 表中的 NEXT_VALUE 值.
适用范围:
  • 由于 hilo 生存标识符机制不依赖于底层数据库系统, 因此它适合所有的数据库系统
  • OID 必须为 long, int 或 short 类型, 如果把 OID 定义为 byte 类型, 在运行时会抛出异常

hilo 和 seqhilo生成器给出了两种hi/lo算法的实现
第一种情况:
<id name="id" type="id" column="id">
<generator class="hilo">
<param name="table">zhxy_hilo_tbl</param>
<param name="column">next_value</param>
<param name="max_lo">100</param>
</generator>
</id>
第二种情况需要sequence的支持,这里只讨论更通用的第一种情况默认请况下使用的表是hibernate_unique_key,默认字段叫作next_hi。next_hi必须有一条记录否则会出现错误。
几个简写解释:
hi:高值-从数据库取得的那个值
lo:低值-hibernate自动维护,取值1到max_low
max_low:映射文件中配置的

那个值那hibernate怎样生成主键呢?
1.从数据库中取得hi值,数据库的next_value值加1
2.hibernate取得lo值(0到max_lo-1循环,lo到max_lo时,执行步骤1,然后lo继续从0到max_lo-1循环)

根据下面的公式计算值:
hi*(max_lo+1)+lo;

例如hi初始为2,max_lo为3
生成的值依次是:
读取hi为2,写到数据库为3
2*(3+1)+0=8
2*(3+1)+1=9
2*(3+1)+2=10
2*(3+1)+3=11
这有次读写表zhxy_hilo_tbl操作,hi变为3,数据库成为4
3*(3+1)+0=12
3*(3+1)+1=13
关闭数据库,下次打开时,读取hi值为4,数据库变为5
4*(3+1)+0=16
但是有一种特殊情况,就是hi是0的时候,那么第一个值不是0*(max_lo+1)+0=0
而是跳过0,直接就是1 

native 标识符生成器
native 标识符生成器依据底层数据库对自动生成标识符的支持能力, 来选择使用 identity, sequence 或 hilo 标识符生成器.
适用范围:
  • 由于 native 能根据底层数据库系统的类型, 自动选择合适的标识符生成器, 因此很适合于跨数据库平台开发
  • OID 必须为 long, int 或 short 类型, 如果把 OID 定义为 byte 类型, 在运行时会抛出异常

Property
hibernate 对象关系映射文件详解_第10张图片 hibernate 对象关系映射文件详解_第11张图片
hibernate 对象关系映射文件详解_第12张图片
hibernate 对象关系映射文件详解_第13张图片

Java 类型, Hibernate 映射类型及 SQL 类型之间的对应关系
hibernate 对象关系映射文件详解_第14张图片
hibernate 对象关系映射文件详解_第15张图片




你可能感兴趣的:(Hibernate)