zoukankan      html  css  js  c++  java
  • hibernate主键generator属性介绍

    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>联合一起使用。

    <id>元素中的<generator>用来为该持久化类的实例生成唯一的标识,hibernate提供了很多内置的实现。

    Increment:由hibernate自动递增生成标识符,用于为long, short或者int类型生成唯一标识。 
    identity :由底层数据库生成标识符(自动增长),返回的标识符是 long, short 或者int类型的。
    sequence :hibernate根据底层数据库序列生成标识符,返回的标识符 是long, short或者 int类型的。

    hilo     :使用一个高/低位算法来高效的生成long, short 或者int类型的标识符。
    uuid.hex :用一个128-bit的UUID算法生成32位字符串类型的标识符。 
    native   :根据底层数据库的能力选择identity, sequence 或者hilo中的一个。 
    assigned :让应用程序在save()之前为对象分配一个标示符。 
    foreign :使用另外一个相关联的对象的标识符。和<one-to-one>联合一起使用。

    一:主键生成策略大体分类: 
    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 
    用于共享主键的时候。(一对一主键关联);

  • 相关阅读:
    快速排序及其优化
    JVM基础:深入学习JVM堆与JVM栈(转)
    java 反射简介(转载)
    java 泛型简介(转载)
    Java 注解简介
    JVM入门必看——JVM结构
    Java多线程详解(转载)
    SpringMVC 实现文件的上传与下载
    死锁简介
    SQL的模糊查询(转载)
  • 原文地址:https://www.cnblogs.com/eternalisland/p/5446811.html
Copyright © 2011-2022 走看看