zoukankan      html  css  js  c++  java
  • [Hibernate开发之路](4)ID生成策略

    一 对象关系数据库映射之Id

    被映射的类必须定义相应数据库表主键字段。大多数类有一个JavaBeans风格的属性, 为每个实例包括唯一的标识。

    <id> 元素定义了该属性到数据库表主键字段的映射。

     

    <id
            name="propertyName"
            type="typename"
            column="column_name"
            unsaved-value="null|any|none|undefined|id_value"
            access="field|property|ClassName"
            node="element-name|@attribute-name|element/@attribute|.">
            <generator class="generatorClass"/>
    </id>
    


    这里主要解说ID生成策略即generator的使用方法

    二  Generator( ID生成策略)

    可选的<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>
    
    全部的生成器都实现org.hibernate.id.IdentifierGenerator接口。 这是一个非常easy的接口;某些应用程序能够选择提供他们自己特定的实现。当然, Hibernate提供了非常多内置的实现。以下是一些内置生成器的快捷名字: 

    (1)uuid 

    用一个128-bit的UUID算法生成字符串类型的标识符, 这在一个网络中是唯一的(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。

    採用XML配置方式

    <hibernate-mapping>
    	<class name="com.model.StudentInfo" table="StudentInfo">
    		<id name="id" column="ID">
                <generator class="uuid"/>
            </id>
    		<property name="name" column = "Name"/>
    		<property name="age" column = "Age"/>
    		<property name="sex" column = "Sex"/>
        </class>
    </hibernate-mapping>

    自己主动生成ID:



    採用uuid方式自己主动生成的ID为string类型




    (2)native

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

    採用XML配置方式

    <hibernate-mapping>
    	<class name="com.model.StudentInfo" table="StudentInfo">
    		<id name="id" column="ID">
                <generator class="native"/>
            </id>
    		<property name="name" column = "Name"/>
    		<property name="age" column = "Age"/>
    		<property name="sex" column = "Sex"/>
        </class>
    </hibernate-mapping>

    採用注解方式:

    @Entity
    public class StudentInfo {
    	private int id;
    	@Id
    	@GeneratedValue(strategy = GenerationType.AUTO)  
    	public int getId() {
    		return id;
    	}
    	public void setId(int id) {
    		this.id = id;
    	}
    }


    自己主动生成ID:



    (3)identity

    对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。

    返回的标识符是long, short 或者int类型的。 

    这样的策略在採用SQL Server时,相当于SQL Server的identitykeyword, 在採用mysql时相当于MySql的auto_incrementkeyword,不能用在Oracle中.

    採用XML配置方式:

    <hibernate-mapping>
    	<class name="com.model.StudentInfo" table="StudentInfo">
    		<id name="id" column="ID">
                <generator class="identity"/>
            </id>
    		<property name="name" column = "Name"/>
    		<property name="age" column = "Age"/>
    		<property name="sex" column = "Sex"/>
        </class>
    </hibernate-mapping>
    採用注解方式:

    @Entity
    public class StudentInfo {
    	private int id;
    	@Id
    	@GeneratedValue(strategy = GenerationType.IDENTITY)  
    	public int getId() {
    		return id;
    	}
    	public void setId(int id) {
    		this.id = id;
    	}
    }

    (4)sequence

    在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence)。 而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。

    採用XML配置方式:

    <hibernate-mapping>
    	<class name="com.model.StudentInfo" table="StudentInfo">
    		<id name="id" column="ID">
                <generator class="sequence">
                	<param name="sequence">student_sequence</param>
                </generator>
            </id>
            
            ......
            
        </class>
    </hibernate-mapping>

    採用注解方式:

    @Entity
    @SequenceGenerator(name = "StudentInfoSEQ", sequenceName = "StudentInfoSEQ_DB") 
    public class StudentInfo {
    	private int id;
    	@Id
    	@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "StudentInfoSEQ")  
    	public int getId() {
    		return id;
    	}
    	public void setId(int id) {
    		this.id = id;
    	}
    }


    在类的前面写

    @Enterty

    @SequenceGenerator(name="", sequenceName="")//sequence生成器。第一个參数是生成器的名字。第二个參数指的是生成到数据库里面的sequence的名字

    在主键的个头方法前写:

    @Id

    @GeneratedValue(strategy=GenerationType.Sequence , generator="上面定义的生成器的名字")//指定生成器的策略

    (5)hilo 

    使用一个高/低位算法高效的生成long, short 或者 int类型的标识符。

    给定一个表和字段(默认各自是 hibernate_unique_key 和next_hi)作为高位值的来源。

    高/低位算法生成的标识符仅仅在一个特定的数据库中是唯一的。


    (6)seqhilo 
    使用一个高/低位算法来高效的生成long, short 或者 int类型的标识符。给定一个数据库序列(sequence)的名字。

    (7)increment 
    用于为long, short或者int类型生成 唯一标识。

    仅仅有在没有其它进程往同一张表中插入数据时才干使用。

    在集群下不要使用。 

    (8)table

    使用一张数据表来管理全部的数据表的主键生成,这个最为麻烦,可是用得好会很方便,尤其是大型项目,数据表许多的时候.这里仅仅举注解的样例

    @Entity
    @TableGenerator(
    		name = "StudentInfo_TG",
    		table = "TableGenerator_Table",
    		pkColumnName = "key",
    		valueColumnName = "value",
    		pkColumnValue = "StudentInfo",
    		allocationSize = 1
    )
    public class StudentInfo {
    	private int id;
    	@GeneratedValue(strategy = GenerationType.TABLE, generator = "StudentInfo_TG")  
    	public int getId() {
    		return id;
    	}
    	public void setId(int id) {
    		this.id = id;
    	}
    }

    @TableGenerator表示这个表要採用table的id生成方式,括号里的各个參数说明:
    name表示生成器的名字,在随后实体的ID中要指明.
    table表示在数据库中生成的管理ID生成策略的表的名字.
    pkColumnName   表字段名称 表示主键的名字
    pkColumnValue  表字段名称 表示主键的值


    valueColumnName 表示这个表要记录的主键的名字,比如这里是StudentInfo,那么在StudentInfo_TG表中就用StudentInfo来记录当前ID值
    allocationSize  表示每次取得一个ID的值之后增长的步长值,这里是每次递增1.

    表结构:

    key value
    StudentInfo 2

    每次须要主键值时,查询名为"TableGenerator_Table"的表,查找字段"key"值为"StudentInfo"的记录,得到这条记录的"value"值为2,依据这个值,和allocationSize的值生成主键值。


    实际上能够理解为:

    select value from TableGenerator_Table where key = 'StudentInfo'






  • 相关阅读:
    201771010101 白玛次仁 《2018面向对象程序设计(Java)》第七周学习总结
    201771010101 白玛次仁 《2018面向对象程序设计(Java)课程学习进度条》
    实验六201771010101 白玛次仁
    第七周作业
    第七周上机练习
    第六周作业
    第六周上机练习
    第五周上机作业
    Java第四周作业
    Java第四次作业
  • 原文地址:https://www.cnblogs.com/slgkaifa/p/7246480.html
Copyright © 2011-2022 走看看