Hibernate枚举类型映射

映射枚举类型:
在枚举里面,一个枚举实例有两个值:
name:枚举的名字,可以使用枚举类型valueOf(String)方发来还原这个枚举类型实例
1.数据库直观2.枚举类型位置随意变化
ordinal:枚举在该类型中的位置,可以使用来sex.values[0]来根据索引位置来还原这个枚举类型实例
1.可以修改枚举类型的名字
1.如果使用名字的方式映射,设置userName为true,如果使用位置的方式,UserName为false

2.记得,枚举类型要写全限定名

public class Employee {
	private Long id;
	private String name;
	private Sex sex;
public enum Sex {
	MALE,FEMALE,UNKNOWN;
}

映射文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- 	hibernate针对每一个对象的映射(mapping)文件 
		package:对象的包-->
<hibernate-mapping package="enums">
	<!-- class:要映射的类型
	table:要把对象保存到的表 -->
	<class name="Employee">
		<id name="id">
			<generator class="native"/>
		</id>
		<property name="name"/>
		<property name="sex">
			<type name="org.hibernate.type.EnumType">
				<param name="enumClass">enums.Sex</param>
				<param name="useNamed">true</param>	
			</type>
		</property>
	</class>
</hibernate-mapping>

测试:

public class EnumTest {
	@Test
	public void testSave(){
		Session session=HibernateUtil.getInstance().openSession();
		session.beginTransaction();
		Employee e=new Employee();
		e.setSex(Sex.FEMALE);
		session.save(e);
		session.getTransaction().commit();
		session.close();
	}
	@Test
	public void testGet(){
		Session session=HibernateUtil.getInstance().openSession();
		session.beginTransaction();
		Employee e=(Employee)session.get(Employee.class, 1L);
		System.out.println(e);
		session.getTransaction().commit();
		session.close();
	}
}

猜你喜欢

转载自blog.csdn.net/qq_36594703/article/details/79587389
今日推荐