<%@ page contentType="text/html; charset=gb2312"%> hibernate3.2上使用UserType范例
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
hibernate3.2上使用UserType范例
     发布者: 发布时间:2008-04-16
仔细看看hibernate的DOC发现不少惊奇的东东,后悔自己的旁门助道是多么的无用.
本次主要实现目的.
数据库表:EchoMessageEmail,其中有三个字段id(自动编号)\name\Email(varchar)
实现目的:数据库字段中Email的值是类似于heweiya@gmail.com;heweiya@21cn.com;www.1718zx.cn的.所以要求以List表达.
也就是生成的DataModel当中是有一个List对象的.
.hbm.xml

xml 代码

<?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">
<!--
Mapping file autogenerated by MyEclipse - Hibernate Tools
-->
<hibernate-mapping>
<class name="com.travelsky.hibernate.po.EchoMessageEmail" table="echo_message_email">
<id name="id" type="java.lang.Integer">
<column name="ID" />
<generator class="native"></generator>
</id>
<property name="name" type="java.lang.String">
<column name="NAME" length="50" not-null="true" />
</property>
<property name="email" type="com.travelsky.hibernate.po.EmailList" lazy="true">
<column name="EMAIL"/>
</property>
</class>
</hibernate-mapping>
对应的POJO:

java 代码

package com.travelsky.hibernate.po;
import java.util.List;

/**
* EchoMessageEmail generated by MyEclipse Persistence Tools
*/

public class EchoMessageEmail implements java.io.Serializable {

private Integer id;
private String name;
private List email;

/** default constructor */
public EchoMessageEmail() {
}

/** minimal constructor */
public EchoMessageEmail(String name) {
this.name = name;
}

/** full constructor */
public EchoMessageEmail(String name, List email) {
this.name = name;
this.email = email;
}


// Property accessors

public Integer getId() {
return this.id;
}

public void setId(Integer id) {
this.id = id;
}

public String getName() {
return this.name;
}

public void setName(String name) {
this.name = name;
}

public List getEmail() {
return email;
}

public void setEmail(List email) {
this.email = email;
}

}
其中的UserType的一个类:EmailList

java 代码

package com.travelsky.hibernate.po;

import java.io.Serializable;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import java.util.ArrayList;
import java.util.List;

import org.apache.commons.lang.StringUtils;
import org.hibernate.HibernateException;
import org.hibernate.Hibernate;

/**
* 必须得引用java.io.Serializable,UserType是反序列化
* 另外,我使用的hibernate版本是3.2,UserType从2.0到3.2有很大的差异,应该多多看看官方的doc
*
* @author @家军.严重注意org.hibernate.usertype.UserType,不要自己造车呀.
*
*/
public class EmailList implements java.io.Serializable,org.hibernate.usertype.UserType{

private List emails;

private static final String SPLITTER = ";";

private static final int[] TYPES = new int[] { Types.VARCHAR };

public int[] sqlTypes() {

return TYPES;
}

public Class returnedClass() {
// TODO Auto-generated method stub
return List.class;
}

public boolean equals(Object x, Object y) throws HibernateException {
if (x == y)
return true;
if (x != null && y != null) {
List xList = (List) x;
List yList = (List) y;
if (xList.size() != yList.size())
return false;
for (int i = 0; i < xList.size(); i++) {
String str1 = (String) xList.get(i);
String str2 = (String) yList.get(i);
if (!str1.equals(str2))
return false;
}
return true;
}
return false;
}

public Object nullSafeGet(ResultSet rs, String[] names, Object owner)
throws HibernateException, SQLException {
String value = (String) Hibernate.STRING.nullSafeGet(rs, names[0]);
if (value != null) {
return parse(value);
} else {
return null;
}
}

public void nullSafeSet(PreparedStatement st, Object value, int index)
throws HibernateException, SQLException {
System.out.println("Set method excecuted");
if (value != null) {
String str = assemble((List) value);
Hibernate.STRING.nullSafeSet(st, str, index);
} else {
Hibernate.STRING.nullSafeSet(st, value, index);
}

}

public Object deepCopy(Object value) throws HibernateException {
List sourcelist = (List) value;
List targetlist = new ArrayList();
targetlist.addAll(sourcelist);
return targetlist;
}

public boolean isMutable() {
return false;
}

private String assemble(List emailList) {
StringBuffer strBuf = new StringBuffer();
for (int i = 0; i < emailList.size() - 1; i++) {
strBuf.append(emailList.get(i)).append(SPLITTER);
}
strBuf.append(emailList.get(emailList.size() - 1));
return strBuf.toString();
}

private List parse(String value) {
String[] strs = StringUtils.split(value, SPLITTER);
List emailList = new ArrayList();
for (int i = 0; i < strs.length; i++) {
emailList.add(strs[i]);
}
return emailList;
}

public Object assemble(Serializable arg0, Object arg1) throws HibernateException {
// TODO Auto-generated method stub
return null;
}

public Serializable disassemble(Object arg0) throws HibernateException {
// TODO Auto-generated method stub
return null;
}

public int hashCode(Object arg0) throws HibernateException {
// TODO Auto-generated method stub
return 0;
}

public Object replace(Object arg0, Object arg1, Object arg2) throws HibernateException {
// TODO Auto-generated method stub
return null;
}

}
测试类:

java 代码

package com.travelsky.test;
import java.util.List;
import java.util.ListIterator;
import com.travelsky.hibernate.po.EchoMessageEmail;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateTest {

public static void main(String[] args) throws Exception{
Configuration config = new Configuration().configure();
SessionFactory factory = config.buildSessionFactory();
Session session = factory.openSession();
Query query = session.createQuery("from EchoMessageEmail as a");
/**
* 理论上来说,这里不存在lazy加载,为了安全起见使用了Iterator
*
*/
ListIterator iterator = query.list().listIterator();
EchoMessageEmail tt = (EchoMessageEmail) iterator.next();//只找第一个
List emails = tt.getEmail();
for (int i = 0; i < emails.size(); i++) {
String emailStr = (String)emails.get(i);
System.out.println(emailStr);
}
session.close();
}
}

Java代码复制代码
  1.   


(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
设计模式入门学习之工厂模式(工厂方法模式)
Oracle存储过程中使用记录类型注意的问题
优化数据库前,问自己10个问题
JaValid 1.0-rc1 版本发布
回复:Java已经输掉了web之战
回复:Java已经输掉了web之战
 
最近评论:
        
鍥炲
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号