主键生成策略

一:主键生成策略种类

1:程序员自己控制  assigned(必须指定主键的值)

2:数据库控制   {(mysql对应)identify, (oracle对应)sequence}

3:跨数据库  native(只需要改变配置的方言即可)

4:hibernate   (increment,uuid,uuid.hex)

5:自定义    identifygrentor接口(企业开发用的最多)

 

详细解释:. 主键生成器要求


  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
      
      
      assigned、native、自定义主键

三:报错

根事务提交的错误(没有动态事务所以要开启动态事务)

解决:工具类中加入如下代码 开启动态事务
        session.beginTransaction();

主键生成策略_第1张图片

 

2:实体类的映射文件中的table 属性name的值没有与数据库表的

 

 

四:案列

工具类:

package com.zking.two.util;

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

/** 工具类的用途
 * 1:方便获取session会话,用来操作数据库
 * 2:用来检验所有映射的配置文件配置是否准确
 * @author Administrator
 *
 */
public class SessionFactoryUtil {
	private static SessionFactory sessionFactory;
	//创建一个本地session
	static {
		Configuration cfg=new Configuration().configure("hibernate.cfg.xml");
		sessionFactory=cfg.buildSessionFactory();
		
	}
	
	//获取session
	public static Session getSession() {
		//拿本地的session
		Session session = sessionFactory.getCurrentSession();
		//判断,如果本地会话为空的话就创建一个本地的会话
		if(session==null) {
			session=sessionFactory.openSession();
		}
		return session;
	}

	//关闭session
	public static void closeSession() {
		Session session = sessionFactory.getCurrentSession();
		if(session!=null&&session.isOpen()) {
			session.close();
		}
	}
	
	/**
	 * 根事务提交的错误(没有动态事务所以要开启动态事务)
	 * Exception in thread "main" org.hibernate.HibernateException: Calling method 'isConnected' is not valid without an active transaction (Current status: NOT_ACTIVE)
	 * @param args
	 */
	public static void main(String[] args) {
		Session session = SessionFactoryUtil.getSession();
		//开启动态事务
		session.beginTransaction();
		System.out.println(session.isConnected());
		SessionFactoryUtil.closeSession();
		System.out.println(session.isConnected());
	}
}

dao方法

package com.zking.two.dao;

import java.io.Serializable;

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

import com.zking.two.entity.Student;
import com.zking.two.entity.Worker;
import com.zking.two.util.SessionFactoryUtil;

public class IdentifierDao {
	
	public Integer addStudent(Student student) {
		Session session = SessionFactoryUtil.getSession();
		Transaction transaction = session.beginTransaction();
		//save方法返回的是序列化的接口 可以强制转化为id对应的类型 即student的id
		Integer sid =(Integer) session.save(student);
		transaction.commit();
		session.close();
		return sid;
	}
	
	public String addWorker(Worker worker) {
		Session session = SessionFactoryUtil.getSession();
		Transaction transaction = session.beginTransaction();
		//save方法返回的是序列化的接口 可以强制转化为id对应的类型 即student的id
		String wid =(String) session.save(worker);
		transaction.commit();
		session.close();
		return wid;
	}

}

实体类对应的映射类




	
	
		
		
		  
			
			
		  
		   
		    
		  
		  
		  
		    
		
		     
		
		
		
		

		
	

entity

package com.zking.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;
	}
	

}

主配置文件




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

		
		thread
		
		
		true
		true


		
		
		
				
		
	

 

你可能感兴趣的:(主键生成策略)