1. 性别枚举类型类:Gender.java
- package com.qiujy.common.myusertype;
- import java.io.Serializable;
- /**
- * 性别枚举类型
- *
- * @author qiujy
- */
- public enum Gender implements Serializable {
- Male( "男" , 0 ), Female( "女" , 1 ), Other( "保密" , 2 );
- private String name;
- private int value;
- public String getName() {
- return name;
- }
- public int getValue() {
- return value;
- }
- private Gender(String name, int value) {
- this .name = name;
- this .value = value;
- }
- public static Gender getGender( int value) {
- if ( 0 == value){
- return Male;
- } else if ( 1 == value){
- return Female;
- } else {
- return Other;
- }
- }
- @Override
- public String toString(){
- return this .name;
- }
- }
2.自定义枚举映射类型类:GenderType.java
- /**
- * Filename: ExportDBScript.java
- * Author: qiujy
- * Createtime:Nov 22, 2008
- * Copyrights 2008 qjyong All rights reserved.
- * EMail: qjyong@gmail.com
- */
- package com.qiujy.common.myusertype;
- import java.io.Serializable;
- import java.sql.PreparedStatement;
- import java.sql.ResultSet;
- import java.sql.SQLException;
- import org.hibernate.Hibernate;
- import org.hibernate.HibernateException;
- import org.hibernate.usertype.UserType;
- /**
- * 自定义hibernate的性别枚举映射类型
- *
- * @author qiujy
- */
- public class GenderType implements UserType {
- /** 告诉Hibernate要使用什么SQL列类型生成DDL */
- public int [] sqlTypes() {
- return new int []{Hibernate.SHORT.sqlType()};
- }
- /** 告诉Hibernate这个UserType用来映射的数据类型。这里是Gender类 */
- @SuppressWarnings ( "unchecked" )
- public Class returnedClass() {
- return Gender. class ;
- }
- /** 告诉hibernate这个类型是不可变的。有微小的性能优化 */
- public boolean isMutable() {
- return false ;
- }
- /**这是用于Hibernate缓存生成的快照,由于Gender是不可变的,直接返回就好了。*/
- public Object deepCopy(Object arg0) throws HibernateException {
- return arg0;
- }
- /** hibernate把这个数据放入二级缓存时要调用的方法 */
- public Serializable disassemble(Object arg0) throws HibernateException {
- return (Serializable)arg0;
- }
- /** 从二级缓存中取这个对象数据时要调用的方法 */
- public Object assemble(Serializable arg0, Object arg1)
- throws HibernateException {
- return arg0;
- }
- /** 处理脱管对象状态的合并。*/
- public Object replace(Object original, Object target, Object owner)
- throws HibernateException {
- return original;
- }
- public boolean equals(Object x, Object y) throws HibernateException {
- return x == y;
- }
- public int hashCode(Object o) throws HibernateException {
- return o.hashCode();
- }
- /** 从JDBC的ResultSet读取属性值。这个方法是在从数据库查询数据时用到。 */
- public Object nullSafeGet(ResultSet rs, String[] names, Object owner)
- throws HibernateException, SQLException {
- int value = rs.getInt(names[ 0 ]);
- return Gender.getGender(value);
- }
- /** 将属性的值设置到PreparedStatement。 */
- public void nullSafeSet(PreparedStatement ps, Object value, int index)
- throws HibernateException, SQLException {
- if (value == null ) {
- ps.setInt(index, Hibernate.SHORT.sqlType());
- } else {
- ps.setInt(index, ((Gender) value).getValue());
- }
- }
- }
3.在映射文件中使用:
- <? xml version = "1.0" encoding = "UTF-8" ?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- < hibernate-mapping >
- < class name = "com.qiujy.domain.Account" table = "account" >
- < id name = "id" column = "id" >
- < generator class = "native" />
- </ id >
- < property name = "loginname" column = "login_name" />
- < property name = "pwd" />
- < property name = "gender" type = "com.qiujy.common.myusertype.GenderType" />
- < property name = "registedTime" type = "timestamp" column = "registed_time" />
- </ class >
- </ hibernate-mapping >