Hibernate 之主键生成策略
目录
- 前言
- 示例
- 准备
- 数据库建表
- 实体类定义和对应的xml配置
- DemoDao
- 程序员自己控制:assigned
- 数据库控制
- identity(标识列/自动增长)
- sequence:内部序列
- Hibernate控制
- increment:最大id+1
- uuid/uuid.hex:生成随机编码
- 自定义主键生成器
前言
Hibernate 之主键生成策略,其实就是生成数据库主键。非常简单,直接看展例吧
示例
准备
数据库建表
t_hibernate_worker
t_hibernate_student
实体类定义和对应的xml配置
Student.hbm.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping><class name="com.cpc.tow.entity.Student" table="t_hibernate_student"><id name="sid" type="java.lang.Integer" column="sid"><!--配置主键生成策略例子: (待会会在这里配置)--><generator class="xxx" /></id><property name="sname" type="java.lang.String" column="sname"></property></class>
</hibernate-mapping>
Student.java
package com.cpc.tow.entity;public class Student {private Integer sid;private String sname;public Integer getSid() {return sid;}public void setSid(Integer sid) {this.sid = sid;}public String getSname() {return sname;}public void setSname(String sname) {this.sname = sname;}@Overridepublic String toString() {return "Student [sid=" + sid + ", sname=" + sname + "]";} }
Worker.hbm.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping><class name="com.cpc.tow.entity.Worker" table="t_hibernate_worker"><id name="wid" type="java.lang.String" column="wid"><!--配置主键生成策略例子: (待会会在这里配置)--><generator class="xxx" /></id><property name="wname" type="java.lang.String" column="wname"></property></class>
</hibernate-mapping>
Worker
package com.cpc.tow.entity;public class Worker {private String wid;private String wname;public String getWid() {return wid;}public void setWid(String wid) {this.wid = wid;}public String getWname() {return wname;}public void setWname(String wname) {this.wname = wname;}@Overridepublic String toString() {return "Worker [wid=" + wid + ", wname=" + wname + "]";}}
在Hibernate的配置文件中添加实体映射文件
<!-- 主键生成策略 --><mapping resource="com/cpc/tow/entity/Student.hbm.xml" /><mapping resource="com/cpc/tow/entity/Worker.hbm.xml" />
准备好了后就开始演示了
DemoDao
该类中定义了两个方法
/*** 添加学生* @param stu* @return*/public Serializable addStudent(Student stu) {Session session = SessionFactoryUtils.openSession();Transaction transaction = session.beginTransaction();Serializable saveId = session.save(stu);transaction.commit();session.close();return saveId;}/*** 添加工人* @param stu* @return*/public Serializable addWorker(Worker worker) {Session session = SessionFactoryUtils.openSession();Transaction transaction = session.beginTransaction();Serializable saveId = session.save(worker);transaction.commit();session.close();return saveId;}
程序员自己控制:assigned
在Student.hbm.xml
中配置:
<id name="sid" type="java.lang.Integer" column="sid"><generator class="assigned" /></id>
测试代码
DemoDao dao = new DemoDao();Student stu = new Student();//自己指定主键stu.setSid(123);stu.setSname("旺旺");System.out.println(dao.addStudent(stu));
数据库中sid列就是123
啦
注意:sid列段必须手动设置,就是数据库中是自动增长列也不行。以xml配置为标准
数据库控制
identity(标识列/自动增长)
在Student.hbm.xml
中配置:
<id name="sid" type="java.lang.Integer" column="sid"><generator class="identity" /></id>
测试代码
DemoDao dao = new DemoDao();Student stu = new Student();stu.setSname("旺旺");System.out.println(dao.addStudent(stu));
数据库中sid列就是使用自动增长列
注意:数据库中sid列段必须为自动增长否则会报错
sequence:内部序列
sequence使用内部序列表来生成主键
mySql数据库中配置
首先我们得在mySql中定义一张hibernate_sequence
表:
并且,在这张表中插入一条初始化数据,为1就行。当然也可以为2。当我们使用内部序列的时候Hibernate就会根据序列表的next_val生成主键,并且修改序列表的next_val(next_val++)方便下一次使用。hibernate_sequence
这张表是默认的也就是不指定序列表时。当然我们也可以指定自己使用的序列表,下面会将,当然指定的表结构和上面操作一样只不过是表名改改。
Oracle数据库中配置
如果你使用的是Oracle数据库那么就是只要创建一个hibernate_sequence
就ok了。
切记数据库的更换一定要修改一下Hibernate的配置文件,除了修改用户密码驱动外还有一个地方要修改,就是Hibernate所采用的数据库sql语言。mySql中用的是一张表Oracle中用的是序列所以这里要修改,不然会报错的噢。
<!--Oracle的配置方式 -->
<property name="dialect">org.hibernate.dialect.OracleDialect</property>
<!--mySql的配置方式-->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
在Student.hbm.xml
中配置:
<id name="sid" type="java.lang.Integer" column="sid"><!-- sequence走内部序列表,默认使用序列表hibernate_sequence --><generator class="sequence" /></id>
指定序列表的话:
<generator class="sequence" ><!-- 指定 aaa 这张表为序列表 --><param name="sequence_name">aaa</param>
</generator>
测试代码
DemoDao dao = new DemoDao();Student stu = new Student();stu.setSname("旺旺");System.out.println(dao.addStudent(stu));
数据库中的sid为序列表生成
问题:
如果不指定生成的序列表那么就采用默认的那个表,所有会产生一个问题就是你可能多长表用一张序列表来生成主键可能造成断号
问题。
Hibernate控制
increment:最大id+1
在Student.hbm.xml
中配置:
<id name="sid" type="java.lang.Integer" column="sid"><!-- 将最大id查出 + 1 数字,无需赋值 --><generator class="increment" /></id>
测试代码
DemoDao dao = new DemoDao();Student stu = new Student();stu.setSname("旺旺");System.out.println(dao.addStudent(stu));
Hibernate内部会做如下操作,将数据库中这长表的最大id查找出来 + 1来生成这次添加的主键.注意列段名最好为int类型
uuid/uuid.hex:生成随机编码
注意:由于随机编码是String类型的所有这里就在 Worker.hbm.xml配置
<id name="sid" type="java.lang.Integer" column="sid"><!-- 随机数生成 32位的编码 --><generator class="uuid" /></id>
特别说明:
uuid 随机数生成 32位的编码
uuid.hex 随机数生成 16位的编码
测试代码
DemoDao dao = new DemoDao();Worker worker = new Worker();worker.setWname("李旺旺");System.out.println(dao.addWorker(worker));
主键就是随机数编码啦,例如像这样的4028ab816bee72a0016bee72a35f0000
一长串编码
自定义主键生成器
如果你对上面的主键生成都不太感兴趣的换,那么没关系我们还可以自定义主键生成
写自定义主键生成类(实现org.hibernate.id.IdentifierGenerator接口)
package com.cpc.tow.id;import java.io.Serializable;
import java.text.SimpleDateFormat;
import java.util.Date;import org.hibernate.HibernateException;
import org.hibernate.engine.spi.SharedSessionContractImplementor;
import org.hibernate.id.IdentifierGenerator;public class Myts implements IdentifierGenerator{@Overridepublic Serializable generate(SharedSessionContractImplementor session, Object object) throws HibernateException {// TODO Auto-generated method stubSimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//这里返回主键生成结果就ok啦return "cpc:" + simpleDateFormat.format(new Date());}
}
Worker.hbm.xml配置
<id name="sid" type="java.lang.Integer" column="sid"><!-- 使用自定义的主键生成策略 --><generator class="com.cpc.tow.id.Myts" /></id>
测试代码
DemoDao dao = new DemoDao();Worker worker = new Worker();worker.setWname("李旺旺");System.out.println(dao.addWorker(worker));
生成的主键就是我们自己定义的啦
Hibernate 之主键生成策略相关推荐
- Hibernate各种主键生成策略与配置详解 - 真的很详细啊!!
1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主 ...
- hibernate之主键生成策略
一.主键类型 1.自然主键(主键本身就是表中的一个字段,实体中一个具体的属性) 表中已经具有某字段,并且该字段具有业务含义作为主键,称之为自然主键. 例如:在person表中的身份证号,既是唯一的,又 ...
- Hibernate各种主键生成策略与配置详解
为什么80%的码农都做不了架构师?>>> 1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibern ...
- Hibernate中主键生成策略
主键生成策略 increment identity sequence native uuid assigned 1) increment 由hibernate完成 主键递增, 原理:select ma ...
- hibernate native oracle,hibernate native 主键生成策略
前一次做个系统用的oracle数据库,使用hibernate生成主键的策略是SEQUENCE,当时觉得很累,因为不知道怎么的,oracle+sequence+trigger怎么也取不到新增数据时的主键 ...
- hibernate 各种主键生成策略(转)
http://www.cnblogs.com/kakafra/archive/2012/09/16/2687569.html 1.assigned 主键由外部程序负责生成,在 save() 之前必须指 ...
- Hibernate主键生成策略总结(这里面讲的很详细)
Hibernate提供的主键生成策略,使我们可以在实体类的映射xml文件中设定关键字来告诉hibernate我们要使用的主键生成方式,然后hibernate会根据设定完成数据库的主键控制. 一.首先通 ...
- 【Hibernate】hibernate主键生成策略与配置详解
//####################################################### **Hibernate各种主键生成策略与配置详解** //############# ...
- Hibernate主键生成策略总结
Hibernate提供的主键生成策略,使我们可以在实体类的映射xml文件中设定关键字来告诉hibernate我们要使用的主键生成方式,然后hibernate会根据设定完成数据库的主键控制. 一.首先通 ...
最新文章
- C++对象模型5——类对象的内存布局
- 创建型模式--原型模式
- c语言:宏里面参数不加括号容易出错,在使用时尽量加括号及举例
- git for windows的下载地址
- 聚合搜索V2.0泛目录站群二开源码 可做指定关键词
- birt报表表格边框_选开源报表开发还是商用?2020报表软件产品整理
- 初始化跟路由相关的定时器
- 谈谈对水晶报表的看法
- gdiplus画直线
- 常用的4种黑盒测试方法
- 数字图像处理第三次试验:图像复原、图像分割
- python3网络爬虫-介绍
- 电脑公司Windows7_X86旗舰版V0911
- FreeMarker常见指令的简单介绍—快速入门(二)
- 网络安全-使用PGP实现电子邮件安全
- 同一个无线局域网(wifi)内,两台电脑无法通过ip通信
- 串口(RS - 232)
- 以太网识别标准及接线标准、接线方法详解
- Photoshop使用技巧
- 亲爱的朋友们,还记得我吗?
热门文章
- 计算机专业英语2013影印版翻译第六章,计算机专业英语2013影印版重点翻译.docx...
- 湖南科技大学计算机科学与工程,【计算机学院】湖南科技大学计算机科学与工程学院前来我校计算机学院进行访问与交流...
- 看见幽灵:Vitalik 终于规范化了以太坊 Casper 协议升级
- 最简单的排序法——sort( )函数
- word中插入smartart图形(插入图形、设置图形格式、在下方插入图形、在后方插入图形)
- 利用Python爬取杭州租房信息,发现月薪没有8K还是不要租房了吧
- DNS 配置正向解析 反向解析
- Spring中单例Bean依赖多例Bean的正确解决方案
- Unity LensFlares(镜头炫光)踩坑以及解决总结
- 进程调度与作业调度的不同点