`
okwang1979
  • 浏览: 31005 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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

阅读更多
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 类型。


分享到:
评论

相关推荐

    借助Hibernate对sybase的image字段类型的处理,实现保存在image类型字段内图片的保存和在页面的显示

    `image`字段类型在Sybase中用于存储大量的二进制数据,如图片、文档等。 首先,我们需要理解Hibernate的工作原理。Hibernate是一个流行的开源对象关系映射(ORM)框架,它允许开发者用面向对象的方式来操作数据库,...

    图片以二进制保存到Oracle,取出并显示到页面示例

    在Oracle数据库中,我们创建了一个名为`images`的表,包含`id`和`image_data`两个字段,其中`image_data`字段是BLOB类型,用于存储图片的二进制数据。 当需要从数据库中取出图片并显示在网页上时,可以使用类似的...

    struts+hibernate实现文件上传、下载,以二进制存于数据库

    文件数据会被存储到一个二进制字段(通常是BLOB类型)中。 在**文件存储**阶段,文件以二进制形式存入数据库具有一定的优缺点。优点包括:数据安全性高,不会因文件系统问题导致文件丢失;便于备份和恢复;可以实现...

    Hibernate读取blob字段

    在Java的持久化框架Hibernate中,Blob类型常用于存储大对象(Large Object),如图片、音频、视频或大型文本文件等。本篇文章将深入探讨如何使用Hibernate读取数据库中的Blob字段,以及涉及到的相关知识点。 首先,...

    Spring+Hibernate处理Oracle lob字段(一)

    在Oracle数据库中,LOB字段主要有BLOB(Binary Large Object)和CLOB(Character Large Object)两种类型,分别用于存储二进制和字符数据。处理这些字段时,我们需要配置Hibernate的实体类和映射文件。 在实体类中...

    Hibernate-Oracle-MySQL-image.rar_oracle

    这篇文档“Hibernate-Oracle-MySQL-image.rar_oracle”聚焦于使用Hibernate处理Oracle和MySQL数据库中的二进制大对象(Blob),特别关注如何存储和检索图片文件。Blob类型常用于存储大型数据,如图像、音频或视频...

    Struts+hibernate图片上传

    例如,我们可能有`id`(主键)、`fileName`(图片文件名)、`contentType`(图片类型)、`data`(图片二进制数据)等字段。 在业务逻辑层,我们需要编写一个服务类(如`ImageService`),该类将调用Hibernate的...

    Hibernate将图片插入数据库

    在IT行业中,数据库不仅仅是用来存储文本数据,还可以处理各种类型的二进制数据,如图片、音频文件等。这里我们关注的是如何使用Hibernate框架将图片这种二进制文件插入到数据库中。Hibernate作为Java领域的一个流行...

    Hibernate对BLOB CLOB操作

    BLOB用于存储二进制数据,例如图片或文档,而CLOB则用于存储大量的字符数据,如长篇的文本内容。在数据库中,这两个类型通常用来处理那些超出了普通列大小限制的数据。 首先,我们需要了解Hibernate的配置文件,也...

    hibernate保存图片

    Blob(Binary Large Object)是一种用于存储大量二进制数据的数据类型,例如图像、音频或视频文件等。在MySQL数据库中,Blob字段非常适合用来存储图片数据。Blob字段有四种类型:TINYBLOB、BLOB、MEDIUMBLOB 和 ...

    存图片到数据库

    在Hibernate映射文件`UserInfo.hbm.xml`中,`&lt;property name="image" type="binary"&gt;`这一部分配置了`image`字段为二进制类型,表示该属性将在数据库中作为BLOB(Binary Large Object)存储。 接下来,我们看下...

    hibernate向oracle插入图片

    Oracle数据库支持BLOB(Binary Large Object)类型,用于存储大容量的二进制数据,如图片、音频或视频文件。在Hibernate中,我们可以通过定义一个BLOB类型的字段来映射图片数据。 【三】准备环境 1. 首先,确保已...

    解析使用jdbc,hibernate处理clob/blob字段的详解

    在Java的数据库操作中,`CLOB`和`BLOB`是用于存储大对象(Large Object)的数据类型,分别用于存储字符数据和二进制数据。这篇文章主要讲解了如何使用`JDBC`和`Hibernate`这两种不同的方式来处理`CLOB`和`BLOB`字段...

    在flex的dataGrid控件中显示图片的实践

    本文将深入探讨如何在DataGrid中显示图片,特别是在与Spring、Hibernate和Struts等框架集成的背景下,如何处理二进制数据并将其在Flex前端呈现。 首先,让我们了解Flex的基本概念。Flex是一个基于ActionScript和...

    hibernate注解

    - **BLOB/CLOB**:二进制大对象/字符大对象,用于存储大数据量的信息。 以上概述了Hibernate注解的基本概念和常用注解的使用方式。通过合理地使用这些注解,开发人员可以构建出高效且易于维护的持久层代码。

    将图片以字节流存到数据库再从数据库获取显示

    通常,我们会选择支持二进制大对象(BLOB)的数据库,如MySQL、PostgreSQL或Oracle等,用于存储字节流数据。创建一个表,包含一个BLOB类型的字段,用于存放图片数据。然后,通过SQL语句或者ORM框架(如Hibernate或...

    SSH+Oracle上传图片

    在对应的Hibernate映射文件中,使用`&lt;property&gt;`标签将`img`字段映射到数据库的`IMG`列,类型指定为`BlobByteArrayType`,以便处理二进制数据。 ```xml &lt;property name="img" type="org.springframework.orm....

    java将图片写入数据库,并读出来(blob clob)

    Blob用于存储二进制数据,如图片、音频或视频文件,而Clob则用于存储字符数据,比如长文本。以下是如何使用Java处理Blob类型的图像数据的详细步骤: 1. **连接数据库** 使用JDBC(Java Database Connectivity)API...

    20个数据库设计最佳实践

    - **实践要点**:大二进制对象(BLOB)和图像(IMAGE)类型的字段不应存储在常用表中。 - **实现技巧**:如果确实需要存储此类数据,考虑使用独立的存储解决方案,如云存储服务。 #### 19. 合理运用规范化原则 - **...

    关于struts2.1.6上传图片到数据库的简单项目

    通过这个项目,我们可以学习到Struts2的文件上传、数据库操作以及在页面上显示二进制数据等核心概念。在实际应用中,你可能还需要考虑错误处理、安全性(如防止SQL注入和非法文件上传)以及性能优化等方面的问题。

Global site tag (gtag.js) - Google Analytics