首页 > 代码库 > hibernate之2.CRUD
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); } } }
hibernate之2.CRUD