文档章节

Hibernate的ID生成策略

maskleo
 maskleo
发布于 2015/10/15 22:11
字数 866
阅读 11
收藏 0
点赞 0
评论 0

1.介绍

Hibernate是目前最为常用的ORM框架,当然也有人会选择iBATIS或者其他的架构.这里我们着重讲Hibernate的ID生成策略

 

2.可选的ID策略生成方式

 

(1)native/auto

根据不同的数据库采用不同的ID生成方式,例如:在SQL Server中采用identity; 在MySQL中采用auto_increment; 在ORACLE中就会采用sequence, 注意hibernate会自动帮你创建一个名字叫hibernate_sequence的序列,不用自己去创建.这也是最常用和省事的.

 

例子:采用xml方式配置

 

<hibernate-mapping>
 <class name="abu.csdn.bean.User" table="users">
  <id column="uid" name="uid" type="java.lang.Long">
   <generator class="native"/>
  </id>

   .....

  </class>

<hibernate-mapping>

例子:采用注解方式(注意只要在id的getter上写上@Id就可以了,默认就是@GeneratedValue(strategy = GenerationType.AUTO), 另外(strategy = GenerationType.AUTO)也可以不写.)以下3种方式结果都是一样.

(a)

@Entity(name = "users")
public class User {

    private long uid;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    public long getUid() {
        return uid;
    }

    public void setUid(long uid) {
        this.uid = uid;
    }
}

(b)

@Entity(name = "users")
public class User {

    private long uid;

    @Id
    @GeneratedValue
    public long getUid() {
        return uid;
    }

    public void setUid(long uid) {
        this.uid = uid;
    }
}

 

 (c)

@Entity(name = "users")
public class User {

    private long uid;

    @Id
    public long getUid() {
        return uid;
    }

    public void setUid(long uid) {
        this.uid = uid;
    }
}

 

(2)identity

这种策略在采用SQL Server时,相当于SQL Server的identity关键字, 不能用在Oracle中.

例子:采用xml配置方式

<hibernate-mapping>
 <class name="abu.csdn.bean.User" table="users">
  <id column="uid" name="uid" type="java.lang.Long">
   <generator class="identity"/>
  </id>

   .....

  </class>

<hibernate-mapping>

 

例子:采用注解方式

@Entity(name = "users")
public class User {

    private long uid;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    public long getUid() {
        return uid;
    }

    public void setUid(long uid) {
        this.uid = uid;
    }
}

(3)sequence

当然采用sequence的就是oracle了.生成方式开始已经说过了.如果要指定sequence的名字那么请看下面两个例子

例子:采用xml配置

<hibernate-mapping>
 <class name="abu.csdn.bean.User" table="users">
  <id column="uid" name="uid" type="java.lang.Long">
   <generator class="sequence">
      <param name="sequence">csu_user_sequence</param>   </generator>
  </id>
   .....
  </class>
<hibernate-mapping>

例子:采用注解方式

@Entity(name = "users")
@SequenceGenerator(name = "userSEQ", sequenceName = "csu_user_sequence")
public class User {

    private long uid;

    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "userSEQ")
    public long getUid() {
        return uid;
    }

    public void setUid(long uid) {
        this.uid = uid;
    }
}

(4)table

使用一张数据表来管理所有的数据表的主键生成,这个最为麻烦,但是用得好会非常方便,尤其是大型项目,数据表非常多的时候.这里只举注解的例子,后说明

@Entity
@TableGenerator(name = "csdnGenerator", table = "csdn_generator", pkColumnName = "keyName", valueColumnName = "keyValue", pkColumnValue = "teacher", allocationSize = 1)
public class Teacher implements Serializable {
    @Id
    @GeneratedValue(strategy = GenerationType.TABLE, generator = "sisTableGen")
    public long getTeaId() {
        return teaId;
    }

    public void setTeaId(long teaId) {
        this.teaId = teaId;
    }
}

 

 说明:

(a)@TableGenerator表示这个表要采用table的id生成方式,括号中的各个参数说明:

(i) name表示生成器的名字,在随后实体的id中要指明.

(ii)table表示在数据库中生成的管理id生成策略的表的名字.

(iii)pkColumnName表示主键的名字,也就是说记录每个表主键的名字

(iv)pkColumnValue表示主键的值,每个表主键的值

(v)valueColumnName表示这个表要记录的主键的名字,例如这里是teacher,那么在csdn_generator表中就用teacher来记录主键的值

(vi)allocationSize表示每次取得一个主键的值之后增长的步长值,这里是每次递增1.

(b)@GeneratedValue表示在主键中指明具体的id生成策略,,strategy表示要采用的ID生成策略,由于这里采用的是table,当然就是GenerationType.TABLE了,generator指出id生成器的名字,这里就是csdnGenerator.

版权声明:本文为博主原创文章,未经博主允许不得转载。

本文转载自:http://blog.csdn.net/csuliky/article/details/5719304

共有 人打赏支持
maskleo
粉丝 14
博文 128
码字总数 17344
作品 0
深圳
程序员
Hibernate学习之SessionFactory的opensession 和 getCu...

1 。 Hibernate 的 Id 生成策略 XXOO.hbm.xml 下 class 标签的 主键id 标签中 使用 <generator/> 标签指定 生成策略。 <hibernate-mapping> <class name="com.myeclipse.OneToOne.Student2" ......

coffee_guy
2013/03/01
0
0
Hibernate4之JPA规范配置详解

@Table Table用来定义entity主表的name,catalog,schema等属性。 属性说明: name:表名 catalog:对应关系数据库中的catalog schema:对应关系数据库中的schema UniqueConstraints:定义一...

Zhao-Qian
2013/11/11
0
0
JPA主键生成器和主键生成策略

JPA中创建实体时,需要声明实体的主键及其主键生成策略。我们有一个实体类叫做Email,其主键上声明如下: @Id@Column(name = "EMAIL_ID")@GeneratedValue(strategy = GenerationType.SEQUENC...

Element0506
2015/11/13
0
0
基于按annotation的hibernate主键生成策略

这里讨论代理主键,业务主键(比如说复合键等)这里不讨论。 一、JPA通用策略生成器 通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id, 其生成规则由@Generate...

_白开水_
2013/10/02
0
0
【hibernate】 hibernate的主键策略

今天使用maven生成一个sping+springMVC+hibernate 的项目,报错如下: 错误提示呢:不能解释这个id的生成策略【uuid.string】。就是uuid.string这个hibernate不支持。 奇怪了, 网上查看别人...

angel挤一挤
2016/06/20
0
0
常用Hibernate 主键生成策略

ORM映射基本原理 1. 基于相同实体类和表,实现相互映射,类的对象对应了表中的记录,不同对象对应不同的记录,不同的记录对应不同的对象 2. 表中不同的记录通过主键来区分,不同的对象通过对...

徐文瑞
2013/03/09
0
1
Pgsql 使用UUID做主键

数据库生成主键的几种策略(前言) 这里可以参考:基于按annotation的hibernate主键生成策略 使用UUID做主键 两种方式: 使用Hibernate 提供的Type 方式(建议方式) 使用Converter (自定义属性转...

OrangeJoke
2016/09/18
48
0
hibernate创建oracle中的表添加数据为什么还是使用的还是hibernate自己的序列

seqidsupervision 自己创建的序列: create sequence seqidsupervision minvalue 1 start with 1 in

icecrem
2017/12/14
2
0
Hibernate映射——一对一双向关联映射(六)

我们介绍了一对一的单向关联映射,单向是指只能从人(Person)这端加载身份证端(IdCard),但是反过来,不能从身份证端加载人得信息。如图所示: 关键原因在于对象模型具有方向性: 单向:一...

architect刘源源
01/11
3
0
Hibernate各种主键生成策略与配置详解 - 真的很详细啊!!

1、assigned 主键由外部程序负责生成,在 save() 之前必须指定一个。Hibernate不负责维护主键生成。与Hibernate和底层数据库都无关,可以跨数据库。在存储对象前,必须要使用主键的setter方法...

52PiggySky
2013/11/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

c++ qt 组播总结

每个人都有不同的认知规律和习惯, 有的人喜欢搞一套严密的大理论, 论述起来滔滔不绝, 不管自己懂不懂, 反正读者/听者是没搞懂。 有的人喜欢从实践出发, 没看到代码, 不运行一下, 不看...

backtrackx
7分钟前
0
0
Sublime text2安装json格式化插件SublimePrettyJson[Windows]

一、下载SublimePrettyJson插件包 https://github.com/dzhibas/SublimePrettyJson 二、将下载的文件解压放到在package目录下面 C:\Users\lucky\AppData\Roaming\Sublime Text 3\Packages 每个......

lazy~
7分钟前
0
0
安装vue-cli 报4058错误

1. 4058是网络代理错误。 安装淘宝源修改一下就可以了: npm --registry https://registry.npm.taobao.org info underscore 改为cnpm执行: cnpm install --global vue-cli 安装成功: 试试版...

MrBoyce
8分钟前
0
0
CPU飙升分析

1、top -----看具体的进程 2、top -H -p pid ------该进程的线程 3、printf 0x%x 15248 ------将线程改为16进制 4、jstack 进程...

北极之北
11分钟前
1
0
新生代Eden与两个Survivor区的解释

聊聊JVM的年轻代 1.为什么会有年轻代 我们先来屡屡,为什么需要把堆分代?不分代不能完成他所做的事情么?其实不分代完全可以,分代的唯一理由就是优化GC性能。你先想想,如果没有分代,那我...

浮躁的码农
13分钟前
0
0
【JVM】JSTATD结合Java VisualVM进行远程监控JVM运行情况(二)

内存泄露指的是程序中动态分配内存给一些临时对象,但是对象不会被GC(java垃圾回收机制gabage collection)所回收,它始终占用内存。即被分配的对象很大但已无用; 内存溢出指的是程序运行过...

大白来袭
16分钟前
2
0
聊聊ribbon的超时时间设置

序 本文主要研究一下ribbon的超时时间设置 配置 实例 ribbon: ReadTimeout: 10000 ConnectTimeout: 10000 MaxAutoRetries: 0 MaxAutoRetriesNextServer: 1 eureka: enabled: ......

go4it
24分钟前
0
0
一行代码结果叹为观止,能做到这么极致的也只有python了

Python 这门语言非常的有趣,不仅可以做高大上的人工智能、大数据、机器学习。还可以用来做 Web、爬虫。还有其它很多的应用。今天我就给大家展示下一行 Python 代码都可以做些什么。 一行打印...

猫咪编程
28分钟前
2
0
KingShard使用

对于kingshard的功能,在git中可以看到明确的功能说明 主要功能: 1. 基础功能 支持SQL读写分离。 支持透明的MySQL连接池,不必每次新建连接。 支持平滑上线DB或下线DB,前端应用无感知。 支...

mickelfeng
30分钟前
0
0
Linux 下 查找某个字符串

如果你想在当前项目下 查找 "test" 这个字符串,可以这样: grep -rn "test" * * : 表示当前目录所有文件,也可以是某个文件名-r 是递归查找-n 是显示行号-R ...

nsns
30分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部