`

Sequence生成器@ Sequence

    博客分类:
  • java
阅读更多

在一些特殊的数据库中,比如Oracle中可以使用Sequence来生成自动主键。若要在Entity中使用Sequence作为主键的生成策略,则步骤如下所示。

(1)在数据库中创建一个Sequence,SQL脚本如下。

CREATE SEQUENCE customer_sequence START WITH 1 INCREMENT BY 10;

这个Sequence从1开始,每次增长10。

提示:本书采用的MySQL数据库中不支持Sequence,所以此策略不适用于MySQL。

(2)在Entity标记主键的位置,指定主键生成策略为“GenerationType. SEQUENCE”,具体设置如下。

@Entity

@Table(name = "customer")

public class CustomerEO implements java.io.Serializable {

 

         private Integer id;

 

         @Id

         @GeneratedValue(strategy = GenerationType.SEQUENCE)

         public Integer getId() {

                   return this.id;

         }

 

         public void setId(Integer id) {

                   this.id = id;

         }

}

(3)指定生成主键策略的名称,例如这里命名为“customer_seq”。

         @Id

         @GeneratedValue(strategy = GenerationType. SEQUENCE,generator="customer_seq")

         public Integer getId() {

                   return this.id;

         }

(4)使用@ SequenceGenerator标记定义Seqence生成策略的具体设置,代码如下所示。

         @Id

         @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="customer_seq")

         @SequenceGenerator(name="customer_seq",

                            sequenceName="customer_sequence"

         )

         public Integer getId() {

                   return this.id;

         }

 

         public void setId(Integer id) {

                   this.id = id;

         }

注释@SequenceGenerator用于设置主键使用Sequence生成主键的策略,它的定义如下所示。

@Target({TYPE, METHOD, FIELD}) @Retention(RUNTIME)

public @interface SequenceGenerator {

String name();

String sequenceName() default "";

int initialValue() default 0;

int allocationSize() default 50;

}

在使用此@ SequenceGenerator标记时,需要注意以下几个问题。

l         与@ TableGenerator标记类似,@ SequenceGenerator也可以标注在类、属性和方法前,并且作用域是整个persist unit的范围。

l         name属性表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中。

l         sequenceName属性值表示数据库中创建的Sequence的名称。

l         initialValue表示主键初识值,默认为0。

l         allocationSize表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50。

-----------------------------------------------------------------

Hibernate为优秀的持久层框架的代表。在传统的JDBC+JavaBean操作中,实体对象都由程序员自己去封装,然后返回。而在Hibernate中,采用对象关系映射『ORM』,大大简化了对数据库的操作.

在数据库的设计和操作中,我们通常会给表建立主键。
主键,可以分为自然主键和代理主键。
自然主键表示:采用具有业务逻辑含义的字段作为表的主键。比如在用户信息表中,采用用户的身份证号码作为主键。但是这样一来,随着业务逻辑的变化,主键就有可能要更改。比如,假设哪天身份证号码升级成19,2位,那。。。。。。。
代理主键:在表中人为的增加一个字段,该字段并没有表示任何的业务逻辑,仅仅用来标识一行数据。比如说在用户信息表中,增加一个用户ID的字段。用来表示该条用户信息的记录。

通常情况下,用的比较多的是代理主键的形式。而且,我们习惯于于让该主键字段能够自动增长,来保证其唯一性。但是,不同的数据库自动增长的方式并不是相同的。如在SQLSERVER中,用identity,MYSQL中,有increment,ORACLE中通常采用sequence。这样一来,在数据库的主键列操作上,便会显得比较麻烦。
但是在Hibernate中,提供了主键生成策略。下面是比较常用的几种:
1:assigned
----表示在新增数据时由应用程序指定主键的值。主要针对主键是采用自然主键的形式。这种方式,适用于主键列不是自动增长列。

其缺点为在执行新增操作时,需查询数据库判断生成的主键是否已经存在。
2:increment
----表示新增数据操作时由hibernate自动生成主键值。其生成的值为:先查询该主键列的最大值,然后在最大值的基础上加上1.适用于采用代理主键形式的主键列。同样不能用于主键列是自动增长的表。但是,该主键生成策略也有些缺点。
(1)新增数据前先查询一遍,影响了性能。
(2)主键的类型只能为数值型的int或者long
(3)并发操作时的冲突问题。
3:identity
----不如说是为sqlerver数据库量身定做的。主要适用于sqlserver数据库的自动增长列的表。
4:native
----表示根据不同的数据库采用不同的主键生成策略。比如,当前数据库为sqlserver,则会采用identity,如为oracle,则采用

oracle中的sequence等。区分数据库的不同是以hibernate主配置文件中sessionFactory中配置的数据库方言。

  1. <id name="实体类属性名" type="java.lang.Integer">  
  2.       <column name="对应表中主键字段名" />  
  3.       <generator class="assiged|increment|identity|native|........" />  
  4. </id>  


采用hibernate的主键生成策略,就可以比较灵活和方便的对表中的主键字段进行操作了。而且,不同的数据库,不同的主键形式,也只需要修改下映射文件就可以了。 

 

分享到:
评论

相关推荐

    主键生成器sequence

    ### 主键生成器sequence在Oracle中的应用 #### 一、概述 在数据库设计与开发过程中,经常需要为数据表中的某列(通常是主键)自动分配一个唯一且递增的值,以确保每一行记录的独特性。Oracle数据库提供了一种非常...

    SequenceDiagram-3.0.5.zip

    3. **代码生成器**:有些工具能将绘制的序列图转换为编程语言代码,如Java、C#等,这样可以在开发过程中自动生成部分代码,提高效率。 4. **导出和导入功能**:通常具备保存为图片或XML/JSON等格式的功能,便于分享...

    Hibernate内置标识符生成器

    4. Native 标识符生成器:这是一种灵活的策略,Hibernate 会根据底层数据库的特性自动选择合适的生成器,可能是 `identity`、`sequence` 或 `hilo`。这种方式适应性强,但在某些情况下可能无法达到最优性能,因为它...

    sequence_m-sequence_5阶m序列_gold_goldsequence_m序列_

    标题中的"5阶m序列"指的是生成器的反馈多项式阶数为5的M序列。这种序列通常由线性反馈移位寄存器(LFSR)产生,其长度和性质取决于反馈多项式的特定选择。 5阶M序列的生成涉及到反馈多项式的选择和LFSR的操作。反馈...

    Oracle数据库表序列ID自增生成器

    本篇将深入探讨Oracle数据库表序列ID自增生成器及其相关知识点。 首先,序列(Sequence)是Oracle数据库提供的一种机制,它能够按顺序生成唯一的数字,且这个过程是线程安全的。序列可以在不使用表的情况下单独创建...

    oracle 存储过程使用 sequence

    在Oracle中,Sequence则是一种自增序列号生成器,通常用于主键或者唯一标识的生成。在本话题中,我们将深入探讨如何在存储过程中使用Sequence。 首先,理解Sequence的基本概念。Sequence在Oracle中是一个预定义的...

    Nhibernate配置生成器

    4. **标识符(Id)**:对于主键字段,生成器会特别处理,标记为主键并配置相应的标识策略,如Identity、Sequence等。 5. **映射注解或XML配置**:根据选择,生成器会创建NHibernate所需的映射信息,包括表名、字段名...

    sequence-generator:比oracle sequence更加强大的序列生成器,支持分布式环境,配合MHA可完美做到高可用,与spring无缝集成,使用非常简单可靠

    sequence-generator简介类似于oracle的sequence,但更加强大支持分布式环境下sequence的生成使用乐观锁和AtomicLong确保sequence的唯一性使用及其简单db scriptCREATE TABLE sequence_database.sequence ( name ...

    文献阅读笔记|《Sequence to sequence Learning with Neural Networks》

    为了解决这个问题,《Sequence to Sequence Learning with Neural Networks》这篇论文提出了一个新的框架,即基于长短期记忆(LSTM)的编码器-解码器结构。 **1.2 研究内容** 本研究的核心内容是利用LSTM构建的...

    椭圆曲线伪随机序列生成器

    ### 椭圆曲线伪随机序列生成器 #### 引言与背景 伪随机序列(Pseudorandom Sequence, PRS)在多个领域内扮演着关键角色,包括但不限于扩频通信系统、码分多址(CDMA)、软件测试、序列密码学及公钥密码学等。其中...

    序列号生成器

    ### 序列号生成器实现解析 #### 一、概述 本文将深入解析一个Java实现的序列号生成器,该生成器主要用于在分布式系统中生成唯一标识符(ID)。通过分析其核心方法`nextId()`及辅助方法,我们将了解它是如何确保在...

    pn9序列生成器

    综上所述,这段VHDL代码实现了一个PN9序列生成器,其核心在于利用线性反馈移位寄存器来生成周期性的伪随机序列。通过对复位信号和时钟信号的响应,不断更新内部状态,从而实现了PN9序列的生成。这种类型的序列在通信...

    PN_SEQUENCE_GENERATOR.zip_The Given

    PN序列生成器是一种在通信系统中广泛使用的工具,主要用于伪随机噪声码(Pseudo-Noise,简称PN)序列的生成。这些序列在数字通信、无线通信、编码理论以及信号处理等多个领域都有重要的应用。PN序列通常表现为二进制...

    SEQUENCE GENERATOR.pdf

    在这一领域中,【SEQUENCE GENERATOR】作为一种革命性的序列生成器,展现出了高度的灵活性与精确性,尤其在码分多址(CDMA)通信系统中发挥了不可替代的作用。通过专利号EP1078457B1,我们了解到这一技术由著名的...

    SEQUENCE GENERATOR.docx

    本文将对一种特定的序列生成器——SEQUENCE GENERATOR的原理、应用以及其在通信系统中的重要性进行深入探讨。 SEQUENCE GENERATOR,即序列生成器,是一种用于生成二进制或离散值序列的设备。它的核心是移位寄存器,...

    Sequence Tool-开源

    "Sequence Tool"是一款开源软件,专门针对影视后期制作行业的文件序列管理问题而设计。在这一领域,经常需要处理大量的连续图像文件,如DPX、TIFF或JPEG序列,这些文件通常按照数字顺序命名,例如"image1.dpx"、...

    sequence-master.zip

    总结,sequence作为一款分布式高效有序ID生成器,以其卓越的性能和强大的扩展性,为分布式环境下的ID生成问题提供了优秀的解决方案。通过理解其内部原理和优化手段,开发者可以更好地应用和定制sequence,以适应各种...

    Pervasive Attention 2D Convolutional Neural Networks for Sequence-to-Sequence

    传统的Seq2Seq模型通常由一个编码器和一个解码器组成,其中编码器负责捕获输入序列的上下文信息,解码器则基于这些信息生成目标序列。然而,这种架构在某些情况下可能会导致信息丢失或过拟合的问题。 本文提出的...

    apb_sequence_item.rar

    APB是一种常见的总线接口标准,常用于连接微处理器和外围设备,它在系统级设计中扮演着重要角色。 描述中提到的"apb sequence item with rand fields"指出这个项目使用了随机化字段。在系统验证中,特别是使用...

    generator-sequence:Yeoman生成器,用于搭建Sequence.js主题

    生成器序列 生成器,用于构建主题。 入门 什么是Yeoman? 技巧问题。 没关系是这个人: 基本上,他戴着顶帽子,住在您的计算机中,然后等待您告诉他您希望创建哪种应用程序。 并非每台新计算机都预装了Yeoman。 ...

Global site tag (gtag.js) - Google Analytics