hibernate id 映射配置_JAVA_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > JAVA > hibernate id 映射配置

hibernate id 映射配置

 2011/11/2 8:10:33  bean-woo  http://smartgwt.iteye.com  我要评论(0)
  • 摘要:<idname=”id”column=”id”type=”java.lang.Integer”><generatorclass=”native”/></id>上面是一个简单的id映射配置,id属性对应映射类中的属性,column对应数据库中表字段。重点是这个generator<generator></generator><generatorclass="native"></generator><
  • 标签:配置 hibernate
  1. < id ? name =”id”? column =”id”? type =”java.lang.Integer” > ??
  2. ???? < generator ? class =”native” /> ??
  3. </id >

上面是一个简单的 id 映射配置, id 属性对应映射类中的属性, column 对应数据库中表字段。

重点是这个generator<generator></generator><generator class="native"></generator> <generator class="”native”"></generator> ,其中 class 属性可以有以下几种可选类型。

l???????? Assigned

主键由应用逻辑产生,即我们在代码里面指定 id ,数据交由 Hibernate 保存时,主键已经设置完成,无需 Hibernate 干预。

l???????? <st1:place w:st="on"><st1:city w:st="on">hilo </st1:city></st1:place>

通过 hi/lo 算法实现的主键生成机制,需要额外的数据库表保存主键生成历史状态。

l???????? seqhilo

hilo 类似,通过 hi/lo 算法实现的主键生成机制,只是主键历史状态保存在 Sequence 里,适合于支持 sequence 的数据库,例如 Oracle

l???????? increment

主键按数值顺序递增。此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加 1 生成主键。这种方式产生的问题是:如果当前有多个实例访问数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此如果同一数据库由多个实例访问,必须避免这种方式。

l???????? identity

采用数据库提供的主键生成机制,如 SQLServer MYSQL 提供的自增主键生成机制。

l???????? sequence

采用数据库提供的 sequence 机制生成主键,如 Oracle sequence

l???????? native

hibernate 根据数据库适配器中的定义,自动采用 identity hilo sequence 中的一种作为主键生成机制。

l???????? uuid.hex

hibernate 基于 128 位惟一值产生算法,根据当前设备 IP ,时间, JVM 启动时间,内部自增量等四个参数生成 16 进制数值 ( 编码后以 32 位的字符串表示 ) 作为主键。

l???????? uuid.string

uuid.hex 类似,只是生成的主键未生成编码 ( 长度 16 ) ,在某些数据库中可能出现问题,如 PostgreSQL

l???????? foreign

使用外部表的字段作为主键。

l???????? select

hibernate3 中引入新的主键生成机制,主要针对遗留系统的改造工程。

发表评论
用户名: 匿名