一、id
被映射的实体类必须声明一个对应数据库表主键列的属性。大多数类有一个JavaBeans风格的代表此实例唯一标识的属性。<id> 元素定义了该属性到数据库表主键字段的映射。
- <id name="propertyName"
- (1) type="typename"
- (2) column="column_name"
- (3) unsaved-value="null|any|none|undefined|id_value"
- (4) access="field|property|ClassName">
- (5) node="element-name|@attribute-name|element/@attribute|."
- <generator class="generatorClass"/>
- </id>
<id name="propertyName" (1) type="typename" (2) column="column_name" (3) unsaved-value="null|any|none|undefined|id_value" (4) access="field|property|ClassName"> (5) node="element-name|@attribute-name|element/@attribute|." <generator class="generatorClass"/> </id>
(1) name (可选): 标识属性的名字。
(2) type (可选): 标识Hibernate类型的名字。
(3) column (可选 - 默认为实体类的属性名): 数据库表中主键字段的名字。
(4) unsaved-value (可选 - 默认为一个合情理的值): 一个特定的标识属性值,用来标志该实例是刚刚创建的,尚未保存(unsaved),其实就是一个瞬时对象。根据这个值,可以把这种瞬时对象和那种已调用session的save方法保存过以及装载过(loaded)的脱管(detached)对象明确区分开来。
(5) access (可选 - 默认为property): Hibernate用来访问属性值的策略。
如果 name属性缺失的话,就可以假定这个类是没有标识属性的。
unsaved-value属性对Hibernate3来说基本上是不必要的。
还有一个供选择的<composite-id>声明可以访问旧式的多主键数据。我们强烈不鼓励使用这种方式。
二、Generator
可选的<generator>子元素是 一个Java类的名称,用来生成该持久化类实例的唯一标识符。如果这个生成器实例需要某些配置值或者初始化参数,可以使用<param>元素来传递这些参数。
- <id name="id" type="long" column="cat_id">
- <generator class="org.hibernate.id.TableHiLoGenerator">
- <param name="table">uid_table</param>
- <param name="column">next_hi_value_column</param>
- </generator>
- </id>
<id name="id" type="long" column="cat_id"> <generator class="org.hibernate.id.TableHiLoGenerator"> <param name="table">uid_table</param> <param name="column">next_hi_value_column</param> </generator> </id>
所有的生成器都实现了org.hibernate.id.IdentifierGenerator接口。这是一个非常简单的接口;某些应用程序可以选择提供他们自己特定的实现。当然,Hibernate提供了很多内置的实现。下面是一些内置生成器的快捷名字:
increment(递增)
用于为long, short或者int类型生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。
identity (标识)
对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。返回的标识符是long, short 或者int类型的。
sequence (序列)
在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。
hilo (高低位)
使用一个高/低位算法来高效的生成long, short或者 int类型的标识符。给定一个表和字段(默认分别是hibernate_unique_key 和next_hi)作为高位值的来源。高/低位算法生成的标识符只在一个特定的数据库中是唯一的。
seqhilo(使用序列的高低位)
使用一个高/低位算法来高效的生成long, short或者 int类型的标识符,给定一个数据库序列(sequence)的名字。
uuid
用一个128位的UUID算法生成字符串类型的标识符。在一个网络中唯一(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。
guid
在MS SQL Server 和 MySQL 中使用数据库生成的GUID字符串。
native(本地)
根据底层数据库的能力选择identity, sequence 或者hilo中的一个。
assigned (自行分配)
主键由外部程序负责生成,无需Hibernate参与 让应用程序在save()方法调用之前为对象分配一个标示符。这是 <generator>元素没有指定时的默认生成策略。
select
通过数据库触发器选择一些唯一主键的行并返回主键值来分配一个主键。
foreign(外部引用)
使用另外一个相关联的对象的标识符。常常和<one-to-one>联合一起使用。
以下内容摘自:http://ohgrateboy.iteye.com/blog/511019
1:hibernate 负责对主键ID赋值
2:应用程序自己为主键ID赋值(不推荐使用)
3:底层数据库为主键ID赋值
二:具体用法
1:increment:(跨平台的)
以递增的方式为代理主键赋值,每次维护的当前实例中取出一个最大值,在最大值的基础之上再进行加法,适合只有单个应用进程访问数据的情况,否则会产生并发冲突问题(主键重复)。并且oid 的类型必须是long ,int ,short类型的。
2:assigned :由程序员给赋值,(不建议使用)
3:identity:是由底层的数据库来生成主键,他要求底层数据库支持自动增长,并且把主键定义成自动增长类型的 ,oid 必须是long ,int ,short 类型的。
Oracle 不支持。Mysql 支持
4:sequence:由底层的数据根据序列来生成主键。oracle ,db2数据库支持,mysql不支持
5:native:(跨平台的)
由hibernate 自己跟据不同的数据库的主键生成方式,自己选择生成方式(可以跨平台)
6:hilo :(跨平台的),通过hi/lo算法实现主键的生成机制,但是需要额外的表来保存主键的生成历史,使用时要先插入一个值。
使用规则: 通用性和安全性:
7:seqhilo:取得sequence的值,来生成高位,产生id。
但是只能使用于有sequence的数据库(oracle , db2);
8:uuid.hex:
用系统时间和ip地址等具有天然唯一性的资源进行计算,生成id,
全球唯一。生成的是一个128位的二进制数。然后把这个二进制数,转化成一个16进制的数(32位),再转化为字符串付给我们的id。那么我们的实体类的oid以及数据库的主键都需要随之改为字符串类型的。
9:foreign
用于共享主键的时候。(一对一主键关联);
相关推荐
Hibernate映射文件是Hibernate框架中用于定义对象-关系映射(ORM)的重要组成部分。它将Java类与数据库表之间的关系进行详细配置,使得程序能够透明地操作数据库。映射文件通常使用XML格式,并以`.hbm.xml`为扩展名...
Hibernate 配置文件详解 Hibernate 是一个流行的 ORM(Object-Relational Mapping)框架,用于简化 Java 应用程序中的数据库交互。 Hibernate 的配置文件是其核心组件之一,用于定义 Hibernate 的运行期参数。下面...
### Hibernate映射文件基础结构 映射文件通常以`<!DOCTYPE hibernate-mapping>`开头,引用DTD(文档类型定义),确保文件遵循正确的格式。例如: ```xml <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/...
### 深入理解Hibernate映射文件 #### Hibernate概述与角色 Hibernate是一个开源的对象关系映射(ORM)框架,它让开发人员能够用面向对象的方式处理数据库操作,从而避免了大量的SQL编写工作。Hibernate的设计理念...
在Hibernate中,每个Java类都可以映射到数据库中的一个表,这通过创建一个XML映射文件(如:`User.hbm.xml`)来实现。映射文件定义了类的属性与数据库字段的对应关系,以及主键生成策略等。例如: ```xml <id ...
### Hibernate映射笔记详解 #### Hibernate映射文件与配置关系 Hibernate映射是ORM(对象关系映射)框架中的一项关键技术,它允许开发者在数据库表和Java对象之间建立映射关系,从而简化了数据访问层的开发工作。...
### Hibernate映射文件配置详解 在Hibernate框架中,映射文件(通常为`.hbm.xml`)扮演着Java对象与数据库表之间桥梁的角色,它定义了对象关系映射(ORM)的具体规则。映射文件遵循特定的DTD(Document Type ...
在本文中,我们将深入探讨Hibernate配置文件中的映射元素,这些元素是将对象关系映射到数据库的关键部分。首先,我们需要了解映射文件的基本结构,它通常是一个XML文档,遵循特定的DTD(文档类型定义)。 `...
### 常用Hibernate映射配置详解 #### 1. hibernate-mapping节点解析 `hibernate-mapping`节点是Hibernate映射文件中的顶级节点,用于定义一系列配置选项,控制整个映射文件的行为和映射规则。这些配置包括数据库...
### Hibernate映射关联详解 #### 一、理解一对多双向关联关系 在关系型数据库设计中,一对多关联是常见的数据组织方式之一。而在面向对象编程语言中,这种关系则通常通过集合(如Set或List)来实现。本文将重点...
在Java持久化框架Hibernate中,一对一(One-to-One)映射是对象关系映射的一种常见方式,用于表示两个实体之间一对一的关系。这种关系通常出现在一个实体的实例只能与另一个实体的单个实例相关联的情况。下面我们将...
Hibernate映射文件主键生成策略详解 Hibernate.cfg.xml配置文件是Hibernate框架中的一部分,该文件用于配置Hibernate的各种设置,例如数据库连接、dialect、mapping文件等。在这个文件中,我们可以看到hibernate-...
**hibernate5.2版本配置与映射DTD文件详解** Hibernate 5.2是Java领域中广泛应用的对象关系映射(ORM)框架的一个版本,它允许开发者将数据库操作转化为对象模型,大大简化了数据访问层的开发。在这个版本中,配置...
### Hibernate映射主键生成策略native #### 一、引言 在ORM(对象关系映射)技术中,Hibernate作为一款流行的Java持久层框架,在处理数据持久化方面提供了丰富的功能和灵活性。其中,主键生成策略是Hibernate配置...
以下是一个简单的Hibernate映射文件示例: ```xml <hibernate-mapping> 员工信息 <id name="employeeId" type="long"> <column name="EMPLOYEE_ID" precision="15" scale="0" sql-type="BIGINT" check=...
**hibernate组建映射代码详解** 在Java开发中,Hibernate是一个非常重要的对象关系映射(ORM)框架,它极大地简化了数据库操作。本篇将深入解析“hibernate组建映射”这一主题,帮助初学者理解如何在Hibernate中...
本文将详细介绍Hibernate中的关系映射机制,包括一对一、一对多、多对一以及多对多等不同类型的映射方式,并探讨其背后的原理及最佳实践。 #### 二、Hibernate关系映射基础 ##### 2.1 映射文件简介 在Hibernate中...
### Hibernate中的Generator生成方式详解 在Hibernate框架中,对象与关系映射(ORM)是其核心功能之一,它能够将面向对象模型中的类与数据库表建立对应关系,从而实现对象和数据库之间的转换。而在持久化对象的过程...
在Hibernate中,这些关联可以通过XML配置文件或者注解方式进行映射。以`hibernate_school_01`为例,可能包含如下示例代码: ```xml <!-- XML配置方式 --> <hibernate-mapping> <id name="id" column="SCHOOL_ID...