hibernate如何存储二进制,image等大字段。

[b]model类:[/b]
reportByte字段为数据库二进制类型。

public class PfReportStyle implements java.io.Serializable , Cloneable {

// Fields

/**
*
*/
private static final long serialVersionUID = 1L;

private Long id;

private byte[] reportByte;

// Constructors

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

/** minimal constructor */
public PfReportStyle(Long id) {
this.id = id;
}

/** full constructor */
public PfReportStyle(Long id, byte[] reportByte) {
this.id = id;
this.reportByte = reportByte;
}

// Property accessors

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

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

public byte[] getReportByte() {
return this.reportByte;
}

public void setReportByte(byte[] reportByte) {
this.reportByte = reportByte;
}

}

[b]xml文件[/b]
类型映射为binary

<?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 Persistence Tools
-->
<hibernate-mapping>
<class name="com.bjnkd.report.model.PfReportStyle" table="PF_Report_Style" >
<id name="id" type="java.lang.Long">
<column name="Id" scale="0" />
<generator class="native" />
</id>
<property name="reportByte" type="binary">
<column name="ReportByte" />
</property>
</class>
</hibernate-mapping>


[b]测试方法[/b]

public void testSaveDao() {
PfReportStyle style = new PfReportStyle();
String reportXML = "AAsdsddsfsdfddAA";
byte[] image = reportXML.getBytes();
assertTrue(image != null);
style.setReportByte(image);
assertEquals(true, this.getStyleDao().saveStyle(style));
saveId = style.getId();
logger.error(saveId);
PfReportStyle pfReportStyle = this.getStyleDao().getReportStyleById(
saveId);
for (int i = 0; i < image.length; i++) {
assertTrue(pfReportStyle.getReportByte()[i] == image[i]);
}
String returnStr = new String(pfReportStyle.getReportByte());
assertEquals(returnStr, reportXML);
}

保存类直接调用save方法就可以了。
最后提一句:如果使用blob字段Hibernate.createBlob(InputStream) 方法吧需要存储的内容转一下就OK了。
最后附上主要一般常用映射类型。
integer, long, short, float, double, character, byte, boolean, yes_no, true_false
这些类型都对应Java的原始类型或者其封装类,来符合(特定厂商的)SQL 字段类型。boolean, yes_no 和 true_false都是Java 中boolean 或者java.lang.Boolean的另外说法。

string
从java.lang.String 到 VARCHAR (或者 Oracle的 VARCHAR2)的映射。

date, time, timestamp
从java.util.Date和其子类到SQL类型DATE, TIME 和TIMESTAMP (或等价类型)的映射。

calendar, calendar_date
从java.util.Calendar 到SQL 类型TIMESTAMP和 DATE(或等价类型)的映射。

big_decimal, big_integer
从java.math.BigDecimal和java.math.BigInteger到NUMERIC (或者 Oracle 的NUMBER类型)的映射。

locale, timezone, currency
从java.util.Locale, java.util.TimeZone 和java.util.Currency 到VARCHAR (或者 Oracle 的VARCHAR2类型)的映射. Locale和 Currency 的实例被映射为它们的ISO代码。TimeZone的实例被影射为它的ID。

class
从java.lang.Class 到 VARCHAR (或者 Oracle 的VARCHAR2类型)的映射。Class被映射为它的全限定名。

binary
把字节数组(byte arrays)映射为对应的 SQL二进制类型。

text
把长Java字符串映射为SQL的CLOB或者TEXT类型。

serializable
把可序列化的Java类型映射到对应的SQL二进制类型。你也可以为一个并非默认为基本类型的可序列化Java类或者接口指定Hibernate类型serializable。

clob, blob
JDBC 类 java.sql.Clob 和 java.sql.Blob的映射。某些程序可能不适合使用这个类型,因为blob和clob对象可能在一个事务之外是无法重用的。(而且, 驱动程序对这种类型的支持充满着补丁和前后矛盾。)

imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, imm_serializable, imm_binary
一般来说,映射类型被假定为是可变的Java类型,只有对不可变Java类型,Hibernate会采取特定的优化措施,应用程序会把这些对象作为不可变对象处理。比如,你不应该对作为imm_timestamp映射的Date执行Date.setTime()。要改变属性的值,并且保存这一改变,应用程序必须对这一属性重新设置一个新的(不一样的)对象。


实体及其集合的唯一标识可以是除了binary、 blob 和 clob之外的任何基础类型。(联合标识也是允许的,后面会说到。)

在org.hibernate.Hibernate中,定义了基础类型对应的Type常量。比如,Hibernate.STRING代表string 类型。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值