保证唯一性(auto_increment)

  一、xml方式

 <?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.bjsxt.hibernate.model">
<class name="Student" table="t_student" dynamic-update="true">
<id name="id" >
<generator class="native"></generator>
</id> <property name="name"></property>
</class>
</hibernate-mapping>

  <id> 标签必须配置在 <class>标签内第一个位置。由一个字段构成主键,如果是复杂主键<composite-id> 标签 

  <generator> 元素 (主键生成策略)

  如:<generator class="native"/>  根据是什么数据库,自动选择,mysql默认是 'identity' 即 auto_increment 

    <generator class="uuid "/>  用一个128-bit的UUID算法生成字符串类型的标识符 在Mysql类型是 varchar(255)

  二、annotation方式

  在相应的get方法上使用@GeneratedValues(strategy=GeneratedType)

  strategy 取值:如:strategy=GenerationType.AUTO

  1.AUTO(默认值) - 可以是identity column类型,或者sequence 类型 或者 table 类型取决于不同的底层数据库 相当于 native

    1、对于mysql,使用auto_increment

    2、对于oracle使用hibernate_sequence(名称固定)

  2.TABLE - 使用表保存id值

    就是在数据库中建立一个表,这个表包含两个字段,一个字段表示名称,另一个字段表示值。

    每次在添加数据时,使用第一个字段的名称,来取值作为添加数据的ID,然后再给这个值累加一个值再次存入数据库,以便下次取出使用。  

  @Entity
  @javax.persistence.TableGenerator(
    name="Teacher_GEN",        //生成策略的名称
    table="GENERATOR_TABLE",    //在数据库生成表的名称
    pkColumnName = "pk_key",      //表中第一个字段的字段名 类型为varchar,key
    valueColumnName = "pk_value",   //表中第二个字段的字段名 int ,value
    pkColumnValue="teacher",      //这个策略中使用该记录的第一个字段的值(key值)
    initialValue = 1,            //这个策略中使用该记录的第二个字段的值(value值)初始化值
    allocationSize=1         //每次使用数据后累加的数值
  )
  @GeneratedValue(strategy=GenerationType.TABLE,generator="Teacher_GEN")

  3.IDENTITY - identity column 

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

    返回的标识符是long, short 或者int类型的。 (数据库自增)

    注意:此生成策略不支持Oracle

   

  4.SEQUENCE - sequence
    在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),

    而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。(数据库自增)
    注意:此生成策略不支持MySQL

联合主键(多个字段构成唯一性)

 <hibernate-mapping package="com.bjsxt.hibernate.model">
<class name="Student" table="t_student">
<composite-id name="pk" class="com.bjsxt.hibernate.model.StudentPK">
<key-property name="id"></key-property>
<key-property name="name"></key-property>
</composite-id> <property name="age" />
<property name="sex" />
<property name="good" type="yes_no"></property>
</class>
</hibernate-mapping>

  1.xml方式

    a)建立复合主键类 (必须实现Serializable接口)

    b)在实体类中引用复合主键类

    c)student.hbm.xml 映射文件   

    <composite-id name="studentPK" class=>
      <key-property name="id"/>
      <key-property name="name"/>
    </composite-id>

  2.annotation方式

  三种方法:一般用  2  3

 @Entity
@Table(name="t_teacher")
/*@IdClass(TeacherPK.class)*/
public class Teacher {
private int id;
private String name;
/*private TeacherPK tfk;*/ private int age;
private String teach;
private Date birthday;
private Gender gender;
/*@EmbeddedId
public TeacherPK getTfk() {
return tfk;
}
public void setTfk(TeacherPK tfk) {
this.tfk = tfk;
}*/

  1.将组件类(TeacherPK)注解为 @Embeddable,并将组件的属性(getTPk())注解为@Id

  2.将组件的属性 (getTPk()) 注解为 @EmbeddedId

  3.将类(Teacher)注解为@IdClass,并将该实体类中所有属于主键的属性都注解为@Id

注:不管哪种方式 联合主键类(如:Teacherpk) 需要

  1.实现  Serializable  接口

  2.需要重写equals 和 hashCode方法

    (Teacher类 存到 DB中 需要保证Teacher对象中联合主键唯一,所以需要有equals和hashCode)

4.ID主键生成策略的更多相关文章

  1. Hibernate学习笔记(三)Hibernate生成表单ID主键生成策略

    一. Xml方式 <id>标签必须配置在<class>标签内第一个位置.由一个字段构成主键,如果是复杂主键<composite-id>标签 被映射的类必须定义对应数 ...

  2. Hibernate的ID主键生成策略

    ID生成策略(一) 通过XML配置实现ID自己主动生成(測试uuid和native) 之前我们讲了除了通过注解的方式来创建一个持久化bean外.也能够在须要持久化的bean的包路径下创建一个与bean ...

  3. hibernate(二)主键生成策略

    hibernate主键生成策略主要指的是在实体类orm的配置 <id name=""> <generator class="native"&g ...

  4. 【hibernate】主键生成策略使用UUID报出如下警告:org.hibernate.id.UUIDHexGenerator - HHH000409: Using org.hibernate.id.UUIDHexGenerator which does not generate IETF RFC 4122 compliant UUID values;

    主键生成策略使用UUID报出如警告如下: 控制台- 2017-11-24 18:40:14 [restartedMain] WARN org.hibernate.id.UUIDHexGenerator ...

  5. Hibernate(4)——主键生成策略、CRUD 基础API区别的总结 和 注解的使用

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及的知识点总结如下: hibernate的主键生成策略 UUID 配置的补充:hbm2ddl.auto属性用法 注解还是配置文件 h ...

  6. hibernate主键生成策略

    在hibernate中,提供了多种主键生成器(不同的数据库,不同的表结构使用的主键生成策略也不相同),查阅相关资料经过实验总结如下: 1.increment 主键按照数值顺序递增,使用当前实例中最大值 ...

  7. Hibernate主键生成策略(转)

    1.自动增长identity 适用于MySQL.DB2.MS SQL  Server,采用数据库生成的主键,用于为long.short.int类型生成唯一标识 使用SQL Server 和 MySQL ...

  8. hibernate 注解 主键生成策略

    一.JPA通用策略生成器       通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id, 其生成规则由@GeneratedValue ...

  9. 大家一起撸代码之——Hibernate各种主键生成策略与配置详解

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

随机推荐

  1. .netcore多语言解决方案

    这里本文使用Microsoft.AspNetCore.Localization来实现多语言的解决方案 默认是包含这个包的,所有不需要再额外安装 首先需要注入我们需要的服务 1.在startup.cs中 ...

  2. Java堆大小[z]

    JVM中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制:系统的可用虚拟内存限制:系统的可用物理内存限制. 32位系统下,一般限制在1.5G~2G:64为操作系统对内存 ...

  3. zabbix通过SDK和API获取阿里云RDS的监控数据

    阿里云的RDS自带的监控系统获取数据不怎么直观,想要通过API获取数据通过zabbix显示,因为网上资料缺乏和其他一些原因,获取API签名很困难,但使用阿里云的SDK可以完美避开获取签名的步骤. 阿里 ...

  4. 部署Hadoop-3.0-高性能集群

    一.Hadoop概述: Hadoop是一个由Apache基金会所开发的分布式系统基础架构.用户可以在不了解分布式底层细节的情况下,开发分布式程序.充分利用集群的威力进行高速运算和存储.Hadoop的框 ...

  5. 在Java中使用元组类型的利器

    Java本身并没有内置元组这一项特性,要使用元组必须自行实现,所幸现在这些编程语言都支持泛型, 实现非内置元组也变的异常简单, 但是毕竟是非语言内置的语法元素,使用起来肯定不如原生元组来的便捷. 下面 ...

  6. JAVA 基础编程练习题11 【程序 11 求不重复数字】

    11 [程序 11 求不重复数字] 题目:有 1.2.3.4 个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 程序分析:可填在百位.十位.个位的数字都是 1.2.3.4.组成所有的排列后 ...

  7. TypeError: '<' not supported between instances of 'str' and 'int'

    <不支持str实例和int实例之间的对比 birth是str类型 2000是int类型 所以无法对比,报错 birth = input('birth: ') if birth < 2000 ...

  8. 微信表情js代码

    var list = [], face_list = { "[微笑]": 1, "[撇嘴]": 2, "[色]": 3, "[发呆 ...

  9. Zookeeper白话解释

    官方的解释:Zookeeper提供了诸如统一命名空间服务,配置服务和分布式锁等分布式基础服务. 嗯,说上面这个话的人,良心不会痛吗? Zookeeper功能如上边说到的:统一命名空间服务 其他就tm跟 ...

  10. MQTT 简介及协议原理

    MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议),是一种构建于TCP/IP协议上基于发布/订阅(publish/subscribe)模式的“轻量 ...