hibernate之主键生成策略

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

3. 自定义主键生成器

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

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

4.案例展示

  1. 先导入已经准备好的工具类(作用:简化代码的使用和监测hibernate相关配置是否成功)
package com.xfz.two.util;

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

/**
 * @author ld
 * 本工具类的作用:
 *   1. 简化代码的使用
 *   2. 监测hibernate相关配置是否成功
 */
public class SessionFactoryUtils {
	private static SessionFactory sessionFactory;
	static {
		Configuration cfg = new Configuration().configure("hibernate.cfg.xml");
		sessionFactory = cfg.buildSessionFactory();
	}
	
	public static Session openSession() {
		Session session = sessionFactory.getCurrentSession();
		if(session == null) {
			session = sessionFactory.openSession();
		}
		return session;
	}
	
	public static void closeSession() {
		Session session = sessionFactory.getCurrentSession();
		if(session != null && session.isOpen()) {
			session.close();
		}
	}
	
	public static void main(String[] args) {
		Session session = SessionFactoryUtils.openSession();
		session.beginTransaction();
		System.out.println(session.isConnected());
		SessionFactoryUtils.closeSession();
		System.out.println(session.isConnected());
	}
}
  1. 编写实体类
    Student
package com.xfz.two.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;
	}
	@Override
	public String toString() {
		return "Student [sid=" + sid + ", sname=" + sname + "]";
	}
	
}

Worker

package com.xfz.two.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;
	}
	@Override
	public String toString() {
		return "Worker [wid=" + wid + ", wname=" + wname + "]";
	}
	
}

  1. 导入案例要用的实体映射文件(Student Worker)
    Student.hbm.xml



	
		
		    
			
			
			
            
            
            
            
            
            
			
			
			
			
		
		
		
	

Worker.hbm.xml




	
		
			
			
			
			
			
			
		

		
		
	

  1. 开始写后台代码,dao方法
package com.xfz.two.dao;

import java.io.Serializable;

import org.hibernate.Session;
import org.hibernate.Transaction;

import com.xfz.two.entity.Student;
import com.xfz.two.entity.Worker;
import com.xfz.two.util.SessionFactoryUtils;

public class DemoDao {
	/**
	 * @param stu
	 * @return
	 * 添加学生
	 */
	public Serializable addStu(Student stu) {
		Session session=SessionFactoryUtils.openSession();
		Transaction transaction=session.beginTransaction();
		Serializable save=session.save(stu);
		transaction.commit();
		SessionFactoryUtils.closeSession();
		return save;
	}
	
	/**
	 * @param worker
	 * @return
	 * 添加工人
	 */
	public Serializable addWorker(Worker worker) {
		Session session=SessionFactoryUtils.openSession();
		Transaction transaction=session.beginTransaction();
		Serializable save=session.save(worker);
		transaction.commit();
		SessionFactoryUtils.closeSession();
		return save;
	}
}

  1. 在核心配置文件中配置



	
		
		root
		123
		jdbc:mysql://localhost:3306/mysql?useUnicode=true&characterEncoding=UTF-8
		
		com.mysql.jdbc.Driver
		org.hibernate.dialect.MySQLDialect
        
		
		thread

		
		true
		true

		
		
		
		
		
		
	

  1. 完毕后开始对dao中所写的方法开始测试
package com.xfz.two.dao;

import static org.junit.Assert.*;

import java.io.Serializable;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;

import com.xfz.two.entity.Student;
import com.xfz.two.entity.Worker;

public class DemoDaoTest {
	private DemoDao demoDao=new DemoDao();
//	@Before
//	public void setUp() throws Exception {
//		System.out.println("测试所有要测试的方法之前都会执行的内容(一般用来初始化数据所用)");
//	}
//
//	@After
//	public void tearDown() throws Exception {
//		System.out.println("测试所有要测试的方法之后都会执行的内容(一般用来释放资源所用)");
//	}

	@Test
	public void testAddStu() {
		Student stu=new Student();
		stu.setSname("张三12345");
		//手动控制
		//在主键生成器是程序员控制时,将数据库中的表设置为自动增长最后加进去的数据也是程序员手动设置的值
		//在主键生成器是数据库控制时,表中的值会随自增长来变化
		stu.setSid(86);
		demoDao.addStu(stu);
	}

	@Test
	public void testAddWorker() {
		Worker worker=new Worker();
		worker.setWname("李四112143");
		//uuid主键是随机生成一个32的字符串
		worker.setWid("abcdefgdgfdf");
//		demoDao.addWorker(worker);
		Serializable wid=demoDao.addWorker(worker);
		System.out.println(wid);
	}
	//hibernate能够根据自己连得数据库生成不同的sql语句
	//mysql的sql语句:
//	Hibernate: 
//	    select
//	        next_val as id_val 
//	    from
//	        hibernate_sequence for update
	//oracal的sql语句:
//	    select
//          hibernate_sequence.nextval 
//      from
//          dual
}

  1. 测试结果
    hibernate之主键生成策略_第1张图片
    hibernate之主键生成策略_第2张图片
    hibernate之主键生成策略_第3张图片
    hibernate之主键生成策略_第4张图片
  2. 创建主键生成器类
    实现org.hibernate.id.IdentifierGenerator接口即可,并还可以实现org.hibernate.id.Configurable接口来读取一些配置信息
package com.xfz.two.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{

	@Override
	public Serializable generate(SharedSessionContractImplementor session, Object object) throws HibernateException {
		SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
		return "book_category_"+sdf.format(new Date());
	}

}

显示如下:
hibernate之主键生成策略_第5张图片
在这里插入图片描述

你可能感兴趣的:(上课内容)