model类:
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;
}
}
xml文件
类型映射为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>
测试方法
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 类型。
分享到:
相关推荐
`image`字段类型在Sybase中用于存储大量的二进制数据,如图片、文档等。 首先,我们需要理解Hibernate的工作原理。Hibernate是一个流行的开源对象关系映射(ORM)框架,它允许开发者用面向对象的方式来操作数据库,...
在Oracle数据库中,我们创建了一个名为`images`的表,包含`id`和`image_data`两个字段,其中`image_data`字段是BLOB类型,用于存储图片的二进制数据。 当需要从数据库中取出图片并显示在网页上时,可以使用类似的...
文件数据会被存储到一个二进制字段(通常是BLOB类型)中。 在**文件存储**阶段,文件以二进制形式存入数据库具有一定的优缺点。优点包括:数据安全性高,不会因文件系统问题导致文件丢失;便于备份和恢复;可以实现...
在Java的持久化框架Hibernate中,Blob类型常用于存储大对象(Large Object),如图片、音频、视频或大型文本文件等。本篇文章将深入探讨如何使用Hibernate读取数据库中的Blob字段,以及涉及到的相关知识点。 首先,...
在Oracle数据库中,LOB字段主要有BLOB(Binary Large Object)和CLOB(Character Large Object)两种类型,分别用于存储二进制和字符数据。处理这些字段时,我们需要配置Hibernate的实体类和映射文件。 在实体类中...
这篇文档“Hibernate-Oracle-MySQL-image.rar_oracle”聚焦于使用Hibernate处理Oracle和MySQL数据库中的二进制大对象(Blob),特别关注如何存储和检索图片文件。Blob类型常用于存储大型数据,如图像、音频或视频...
例如,我们可能有`id`(主键)、`fileName`(图片文件名)、`contentType`(图片类型)、`data`(图片二进制数据)等字段。 在业务逻辑层,我们需要编写一个服务类(如`ImageService`),该类将调用Hibernate的...
在IT行业中,数据库不仅仅是用来存储文本数据,还可以处理各种类型的二进制数据,如图片、音频文件等。这里我们关注的是如何使用Hibernate框架将图片这种二进制文件插入到数据库中。Hibernate作为Java领域的一个流行...
BLOB用于存储二进制数据,例如图片或文档,而CLOB则用于存储大量的字符数据,如长篇的文本内容。在数据库中,这两个类型通常用来处理那些超出了普通列大小限制的数据。 首先,我们需要了解Hibernate的配置文件,也...
Blob(Binary Large Object)是一种用于存储大量二进制数据的数据类型,例如图像、音频或视频文件等。在MySQL数据库中,Blob字段非常适合用来存储图片数据。Blob字段有四种类型:TINYBLOB、BLOB、MEDIUMBLOB 和 ...
在Hibernate映射文件`UserInfo.hbm.xml`中,`<property name="image" type="binary">`这一部分配置了`image`字段为二进制类型,表示该属性将在数据库中作为BLOB(Binary Large Object)存储。 接下来,我们看下...
Oracle数据库支持BLOB(Binary Large Object)类型,用于存储大容量的二进制数据,如图片、音频或视频文件。在Hibernate中,我们可以通过定义一个BLOB类型的字段来映射图片数据。 【三】准备环境 1. 首先,确保已...
在Java的数据库操作中,`CLOB`和`BLOB`是用于存储大对象(Large Object)的数据类型,分别用于存储字符数据和二进制数据。这篇文章主要讲解了如何使用`JDBC`和`Hibernate`这两种不同的方式来处理`CLOB`和`BLOB`字段...
本文将深入探讨如何在DataGrid中显示图片,特别是在与Spring、Hibernate和Struts等框架集成的背景下,如何处理二进制数据并将其在Flex前端呈现。 首先,让我们了解Flex的基本概念。Flex是一个基于ActionScript和...
- **BLOB/CLOB**:二进制大对象/字符大对象,用于存储大数据量的信息。 以上概述了Hibernate注解的基本概念和常用注解的使用方式。通过合理地使用这些注解,开发人员可以构建出高效且易于维护的持久层代码。
通常,我们会选择支持二进制大对象(BLOB)的数据库,如MySQL、PostgreSQL或Oracle等,用于存储字节流数据。创建一个表,包含一个BLOB类型的字段,用于存放图片数据。然后,通过SQL语句或者ORM框架(如Hibernate或...
在对应的Hibernate映射文件中,使用`<property>`标签将`img`字段映射到数据库的`IMG`列,类型指定为`BlobByteArrayType`,以便处理二进制数据。 ```xml <property name="img" type="org.springframework.orm....
Blob用于存储二进制数据,如图片、音频或视频文件,而Clob则用于存储字符数据,比如长文本。以下是如何使用Java处理Blob类型的图像数据的详细步骤: 1. **连接数据库** 使用JDBC(Java Database Connectivity)API...
- **实践要点**:大二进制对象(BLOB)和图像(IMAGE)类型的字段不应存储在常用表中。 - **实现技巧**:如果确实需要存储此类数据,考虑使用独立的存储解决方案,如云存储服务。 #### 19. 合理运用规范化原则 - **...
通过这个项目,我们可以学习到Struts2的文件上传、数据库操作以及在页面上显示二进制数据等核心概念。在实际应用中,你可能还需要考虑错误处理、安全性(如防止SQL注入和非法文件上传)以及性能优化等方面的问题。