这里介绍Hibernate使用UserType,UserType就是用户自定义类型,这里的类型指的是除了Hibernate定义的那些类型之外的用户自己定义的。
UserType就是用户自定义类型,这里的类型指的是除了Hibernate定义的那些类型之外的用户自己定义的。
一个实现Hibernate使用UserType接口的 email 类如下(里面的每个方法都是必须实现的接口方法,许多都可以复制粘贴的,不复杂):
/*
* $HeadURL$
* Copyright (c) 2003-2007 Untangle, Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License, version 2,
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but
* AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
* NONINFRINGEMENT. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*/
package com.untangle.uvm.type;
import java.io.Serializable;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import org.hibernate.HibernateException;
import org.hibernate.usertype.UserType;
/**
* Hibernate <code>UserType</code> for persisting
* <code>InetAddress</code> objects.
*
* @author <a href="mailto:amread@untangle.com">Aaron Read</a>
* @version 1.0
*/
public class InetAddressUserType implements UserType
{
private static final int[] SQL_TYPES = { Types.VARCHAR };
public int[] sqlTypes() { return SQL_TYPES; }//该类型对应的 sql 类型
public Class<InetAddress> returnedClass() { return InetAddress.class; }
public boolean equals(Object x, Object y) //equals方法,这个就不用多说了吧,肯定是要用户自定义的
{
if (x == y) { return true; }
if (x == null || y == null) { return false; }
return x.equals(y);
}
public Object deepCopy(Object value) { return value; } // 完全复制的方法,由于是用户自己定义的类型//所以hibernate并不知道要如何来复制这个类,需要用户自己定义
public boolean isMutable() { return false; } // 表示本类型实例是否可变,一般是不可变
- /** *//**//*
- 这才是重头戏!nullSafeGet 和nullSafeSet 是核心所在,对数据的后期处理都在这两个方法里面
- nullSafeGet 是读取的方法
- owner 目前没用到过。
- names 是对应的数据库列名,UserType是可以对应多个列的
- */
public Object nullSafeGet(ResultSet rs, String[] names, Object owner)
throws HibernateException, SQLException
{
String name = rs.getString(names[0]);
if (rs.wasNull()) { return null; }
try {
return InetAddress.getByName(name);
} catch (UnknownHostException exn) {
throw new HibernateException(exn);
}
}
- /**//*
- 保存的方法
- index 是那个 PreparedStatement 的参数序号,一般来说不用管直接往下传
- value 就是要保存的数据,在这边是一个保存着 email 列表的 List
- */
public void nullSafeSet(PreparedStatement ps, Object v, int i)
throws HibernateException, SQLException
{
if (null == v) {
ps.setNull(i, Types.VARCHAR);
} else {
InetAddress addr = (InetAddress)v;
ps.setString(i, addr.getHostAddress());
}
}
public Object replace(Object original, Object target, Object owner)
{
return original;
}
public Object assemble(Serializable cached, Object owner)
{
return deepCopy(cached);
}
public Serializable disassemble(Object value)
{
return (Serializable)deepCopy(value);
}
public int hashCode(Object x)
{
return x.hashCode();
}
}
下来是对应pojo类,这个类用了相应的注解
package com.untangle.uvm.logging;
import java.net.InetAddress;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.Transient;
import org.hibernate.annotations.Type;
import com.untangle.uvm.logging.PipelineEvent;
import com.untangle.uvm.logging.SyslogBuilder;
import com.untangle.uvm.logging.SyslogPriority;
import com.untangle.uvm.node.PipelineEndpoints;
/**
* Log event from the denormalized reports.n_cpd_block_events reports table
*
* @author Sebastien Delafond
* @version 1.0
*/
@Entity
@org.hibernate.annotations.Entity(mutable=false)
@Table(name="n_cpd_block_events", schema="reports")
@SuppressWarnings("serial")
public class CpdBlockEventsFromReports extends LogEvent
{
private InetAddress clientAddress;
private InetAddress serverAddress;
private Integer clientPort;
private Integer serverPort;
private Integer clientIntf;
private Integer proto;
@Column(name="client_address")
@Type(type="com.untangle.uvm.type.InetAddressUserType")//自定义的usertype
public InetAddress getClientAddress() { return clientAddress; }
public void setClientAddress(InetAddress clientAddress) { this.clientAddress = clientAddress; }
@Column(name="server_address")
@Type(type="com.untangle.uvm.type.InetAddressUserType")
public InetAddress getServerAddress() { return serverAddress; }
public void setServerAddress(InetAddress serverAddress) { this.serverAddress = serverAddress; }
@Column(name="client_port")
public Integer getClientPort() { return clientPort; }
public void setClientPort(Integer clientPort) { this.clientPort = clientPort; }
@Column(name="server_port")
public Integer getServerPort() { return serverPort; }
public void setServerPort(Integer serverPort) { this.serverPort = serverPort; }
@Column(name="proto")
public Integer getProto() { return proto; }
public void setProto(Integer proto) { this.proto = proto; }
@Column(name="client_intf")
public Integer getClientIntf() { return clientIntf; }
public void setClientIntf(Integer clientIntf) { this.clientIntf = clientIntf; }
public void appendSyslog(SyslogBuilder sb) // FIXME: not called for now
{
}
@Transient
public String getSyslogId()
{
return ""; // FIMXE ?
}
@Transient
public SyslogPriority getSyslogPriority()
{
// FIXME
return SyslogPriority.INFORMATIONAL;
}
}
分享到:
相关推荐
- `TYPE`:自定义类型映射,需要实现`org.hibernate.usertype.UserType`接口,可以自定义存储和读取的逻辑。 2. **配置枚举类型映射**: 在Hibernate的映射文件(.hbm.xml)中,可以使用`<typedef>`元素定义枚举...
9. **类型转换**:Hibernate允许自定义类型转换,通过实现`UserType`接口,可以将Java类型和数据库类型之间进行定制化的映射。 10. **实体关系映射**:Hibernate通过注解或XML配置文件来描述实体类与数据库表之间的...
11.1.5 使用Hibernate内置映射类型 11.2 客户化映射类型 11.2.1 用客户化映射类型取代Hibernate组件 11.2.2 用UserType映射枚举类型 11.2.3 实现CompositeUserType接口 11.2.4 运行本节范例程序 11.3 ...
- **使用org.hibernate.usertype.UserType**: 实现自定义用户类型。 - **使用org.hibernate.usertype.CompositeUserType**: 映射复合类型。 - **类型注册**: 注册自定义类型。 #### 7. 集合映射 - **持久化集合*...
在使用Hibernate时,确保正确配置并包含必要的JAR(Java Archive)文件至关重要,因为这些库提供了框架运行所需的功能。下面我们将详细探讨Hibernate所需的JAR包及其作用。 1. **hibernate-core.jar**:这是...
Hibernate 是一个强大的 Java 持久化框架,它简化了数据库与对象之间的交互。通过提供一组丰富的API,Hibernate使得开发者能够在应用中轻松地管理和操作数据库数据。...理解并熟练使用这些接口是掌握Hibernate的关键。
在Hibernate中,使用`UserType`可以提升代码质量。`UserType`允许我们自定义数据类型的映射,以便更好地适应特定业务需求。 3. **自定义UserType实例**:例如,如果我们需要在`TUSER`表中存储用户的电子邮件,但不...
Hibernate API 介绍 Hibernate 是一个基于 Java 的开源持久层框架,提供了对数据库的访问和操作接口。下面是 Hibernate API 的详细介绍。 核心接口 1. org.hibernate.cfg.Configuration Interface:配置并启动 ...
- **自定义数据类型**:通过实现 `org.hibernate.usertype.UserType` 接口来自定义数据类型。 通过以上内容的学习,可以全面理解 Hibernate 的基本原理和使用方法,掌握其核心概念和技术要点,从而能够有效地利用 ...
12. **类型转换**:Hibernate允许用户自定义类型转换,通过实现`UserType`接口,可以处理自定义类型与数据库类型的转换。 13. **懒加载(Lazy Loading)**:通过`@OneToMany(mappedBy = "parent", fetch = ...
本文将深入探讨如何使用Hibernate实现领域对象的自定义字段,这涉及到对Hibernate核心概念的理解以及自定义类型的应用。 首先,我们需要了解Hibernate的核心概念。Hibernate主要通过配置文件(hibernate.cfg.xml)...
在Java开发中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它允许开发者使用面向对象的方式来操作数据库,而无需关心底层SQL语句。本文将深入探讨如何在Hibernate配置中设置与数据库字段的对应关系,以及...
这部分可能详细介绍了如何在Hibernate中处理多对多关联,包括使用中间表和Set集合来管理两个实体间的关联。 8. **hibernate_07_003_MTO_SXGL_Category** 和 **hibernate_10_001_composition**: "MTO"可能表示一对...
标题中的“hibernate存取json数据的代码分析”指的是在Java开发中,使用Hibernate框架来存储和检索JSON格式的数据。Hibernate是一个强大的ORM(对象关系映射)框架,它允许开发者将Java对象直接映射到数据库表,但在...
- 如果使用的是HBM(Hibernate Mapping)文件,需要在对应字段上配置`type`属性,指向自定义的`UserType`全限定类名。 通过以上步骤,你可以确保Hibernate在处理MySQL的`TEXT`字段时能够正确地进行序列化、反序列...
在 Hibernate 框架中,使用自定义类型映射 Oracle 中的 LONG 类型字段是一种常见的解决方案。通过实现 UserType 接口,我们可以定制 LONG 类型字段的读写操作。在本例中,我们定义了一个名为 CustomLong 的类,该类...
本例子将详细介绍如何在Hibernate中实现这个功能。 首先,理解Hibernate Domain的概念。Domain是业务逻辑中的实体对象,它对应数据库中的表。通常,我们在创建Domain类时会定义好所有需要的属性,但有些情况下,...
4. **Session接口**:介绍Hibernate的核心组件Session,它是与数据库交互的桥梁,讲解如何创建、打开、关闭Session,以及使用Transaction管理事务。 5. **实体类和持久化对象(POJO)**:解析实体类的设计,如何...
当需要持久化某些来自第三方库的Java类型时,如果这些类型没有提供适当的getter和setter方法,可以考虑实现`org.hibernate.UserType`接口来定义自定义类型。这样可以在不修改原有类的情况下完成持久化任务。 #### ...