主键生成策略

  1. hibernate的主键生成器:
    generator元素:表示了一个主键生成器,它用来为持久化类实例生成唯一的标识 。

1.1 程序员自己控制:assigned

1.2 数据库控制: identity(标识列/自动增长) sequence

1.3 hibernate控制:increment uuid/uuid.hex

1.4 其它:native

student id int
worker id varchar
2. 主键生成器要求
2.1 assigned
数据类型不限、保存前必须赋值

2.2 identity(重点掌握)
数字,无需赋值

2.3 sequence(重点掌握)
数字,无需赋值, 默认使hibernate_sequence这个序列,
也可以通过sequence/sequence_name参数赋值

2.4 increment
数字,无需赋值

2.5 uuid/uuid.hex (是由容器自动生成的一个32位的字符串,.hex代表的是十六进制)
32位的字符串,无需赋值,

2.6 native(重点掌握)
等于identity+sequence

  1. 自定义主键生成器
    3.1 *.hbm.xml指定主键生成器类

3.2 创建主键生成器类
实现org.hibernate.id.IdentifierGenerator接口即可,并还可以实现org.hibernate.id.Configurable接口来读取一些配置信息
PersistentIdentifierGenerator.TABLE
PersistentIdentifierGenerator.PK

  assigned、native、自定义主键

1、hibernateutil工具类
2、程序员自己控制:assigned
3、数据库控制: identity(标识列/自动增长) sequence
4、hibernate控制:increment uuid/uuid.hex
5、其它native
6、自定义主键生成器

案例:myincrement/myts

工具类
package com.zking.two.util;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

/**

  • hibernate工具类
  • 未整合框架前使用
  • @author Administrator

*/
public class HibernateUtils {
private static SessionFactory sessionFactory;
// 存放当前会话
private static ThreadLocal threadLocal = new ThreadLocal();
static {
Configuration cfg = new Configuration();
Configuration configure = cfg.configure(“hibernate.cfg.xml”);
sessionFactory = configure.buildSessionFactory();
}

public static Session openSession() {
	Session session = threadLocal.get();
	if (null == session) {
		session = sessionFactory.openSession();
		threadLocal.set(session);
	}
	return session;
}

public static void closeSession() {
	Session session = threadLocal.get();
	if (null != session) {
		if (session.isOpen()) {
			session.close();
		}
		threadLocal.set(null);
	}
}

public static void main(String[] args) {
	Session session = openSession();
	System.out.println(session.isConnected());
	closeSession();
}

}

送你一个测试数据库
create table t_hibernate_worker
(
wid varchar(32) primary key,
wname varchar(50) not null
);
select * from t_hibernate_worker;
delete from t_hibernate_worker;

create table t_hibernate_student
(
sid int primary key NULL AUTO_Increment,
sname varchar(50) not null
);
select * from t_hibernate_student;
delete from t_hibernate_student;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值