hibernate之2.CRUD

Key Generator(主键产生器)

可选项说明:

1) assigned


主键由外部程序负责生成,无需Hibernate参与。



2) hilo


通过hi/lo 算法实现的主键生成机制,需要额外的数据库表保存主键生成历史状态。



3) seqhilo


与hilo 类似,通过hi/lo 算法实现的主键生成机制,只是主键历史状态保存在Sequence中,适用于支持Sequence的数据库,如Oracle。



4) increment


主键按数值顺序递增。此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。

这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此,如果同一数据库有多个实例访问,此方式必须避免使用。



5) identity


采用数据库提供的主键生成机制。如DB2、SQL Server、MySQL中的主键生成机制。



6) sequence


采用数据库提供的sequence 机制生成主键。如Oralce 中的Sequence。



7) native


由Hibernate根据底层数据库自行判断采用identity、hilo、sequence其中一种作为主键生成方式。



8) uuid.hex


由Hibernate基于128 位唯一值产生算法生成16 进制数值(编码后以长度32 的字符串表示)作为主键。



9) uuid.string


与uuid.hex 类似,只是生成的主键未进行编码(长度16)。在某些数据库中可能出现问题(如PostgreSQL)。



10) foreign


使用外部表的字段作为主键。一般而言,利用uuid.hex方式生成主键将提供最好的性能和数据库平台适应性。


映射文件说明:

<?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.demo.model">

    <class name="Student" table="t_student">
        <id name="studentId" column="student_id">
            <generator class="sequence"/>
        </id>
        <property name="studentName" column="student_name"/>
        <property name="age" />
    </class>
</hibernate-mapping>

package:类的命名空间

class:数据库类所对应的类(实体类)

id:主鍵

name:实体类的属性

column:表的主键字段

generator:主键产生器

class:主键生成的类型,参照上面的主键产生器的可选项说明

property:实体类的属性

name:实体类的属性

column:表的主键字段


提示:

如果name与column的名称相等,column可以不用设置,如:age


CRUD:

package com.demo.model;

import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.junit.Before;
import org.junit.Test;

import com.demo.model.Student;

/**
 * @author wobendiankun
 *2014-10-19 下午08:54:13
 */
public class StudentTest {
	SessionFactory sessionFactory ;
	@Before
	public void init(){
		sessionFactory=new Configuration().configure().buildSessionFactory();
	}
	
	@Test
	public void addTest(){
		Student student=new Student();
		student.setAge(20);
		student.setStudentName("旺财");
		Session session=null;
		try {
			//开启session
			session=sessionFactory.openSession();
			//开启事务
			session.beginTransaction();
			session.save(student);
			//提交事务
			session.getTransaction().commit();
		} catch (HibernateException e) {
			e.printStackTrace();
			//回滚事务
			session.getTransaction().rollback();
			
		}finally{
			if(session!=null){
				session.close();
			}
		}
	}
	@Test
	public void deleteTest(){
		Student student=new Student();
		student.setStudentId(1);
		Session session=null;
		try {
			session=sessionFactory.openSession();
			session.beginTransaction();
			session.delete(student);
			session.getTransaction().commit();
		} catch (HibernateException e) {
			e.printStackTrace();
			session.getTransaction().rollback();
			
		}finally{
			if(session!=null){
				session.close();
			}
		}
	}
	
	@Test
	public void updateTest(){
		Student student=new Student();
		student.setStudentId(2);
		student.setAge(35);
		Session session=null;
		try {
			session=sessionFactory.openSession();
			session.beginTransaction();
			//注意:update方法更新t_student的除了主键外的所有字段,
			//student_name未设置值,默认为空值,
			//表中的数据将被更新为空值
			session.update(student);//update t_student set student_name=?, age=? where student_id=?
			session.getTransaction().commit();
		} catch (HibernateException e) {
			e.printStackTrace();
			session.getTransaction().rollback();
			
		}finally{
			if(session!=null){
				session.close();
			}
		}
	}
	
	@Test
	public void getTest(){
		Session session=null;
		Student student=null;
		try {
			session=sessionFactory.openSession();
			student=(Student) session.get(Student.class, 2);
		}finally{
			if(session!=null){
				session.close();
			}
		}
		System.out.println(student);
	}
	@Test
	public void listTest(){
		Session session=null;
		List<Student> list=null;
		try {
			session=sessionFactory.openSession();
			Query query= session.createQuery("from Student");
			list=query.list();
		}finally{
			if(session!=null){
				session.close();
			}
		}
		for(Student student:list){
			System.out.println(student);
		}
	}
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值