`
guy19867
  • 浏览: 90591 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

SSH保存lob(blob,clob)数据

阅读更多

我们在应用ssh对blob数据进行存储时,会遇到一些细节的问题。这些涉及到了pojo中数据类型的定义,struts,hibernate中数据类型的定义,以及在spring配置文件中的定义等。从网上搜索,关于这些问题的总结如下:

一、问题需求:

 1.在持久化类中字段该用什么类型?
 2.在Struts中文件对应的数据类型是什么?
 3.在Hibernate中字段对应的类型是什么?
 4.如何在Spring中处理这些文件?

二、解决方法:

 1.在数据库中这些文件最终是以字节的形式存储二进制对象,所以在pojo类中将相应的属性定义为byte[]类型

 2.在Struts中可以使用<html:file property="" />标签来上传文件,所以与之对应的ActionForm的属性类型为:
FormFile(org.apache.struts.upload.FormFile)类型
,即使是使用了动态Form同理也是使用该类型.
提示:同时要将form标签修改为<html:form action="/Action.do" method="post" enctype="multipart/form-data">(这是很关键的地方)
以支持文件上传后取得上传数据。在给持久对象赋值时只需调用(FormFile) form.get("property")).getFileData();
方法即可返回byte[]。

 3.在Hibernate中文件列对应的类型可以是org.springframework.orm.hibernate3.support.BlobByteArrayType,
org.springframework.orm.hibernate3.support.ClobStringType、clob、blob、binary。什么时候用BlobBYteArrayType
什么时候用ClobStringType?一般如果要处理的对象是数据库字段类型是blob时(主要是图片,二进制对象等),
映射文件设置为:org.springframework.orm.hibernate3.support.BlobByteArrayType 数据库字段是clob(大文本对象)
类型时,要将java的属性的类型定为String,映射文件设置为: org.springframework.orm.hibernate3.support.ClobStringType。

 4.如果在spring上要使用Struts中自带的上传功能必须在spring的配置文件中加以声明.否者将会出现?
簀ava.lang.IllegalStateException: No LobHandler found for configuration - lobHandler property
must be set on LocalSessionFactoryBean异常。配置如下:

 (1).声明一个处理句柄:
  <bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler" lazy-init="true" />
 (2).在sessionFactory中注入lobHandler:
  <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
          <property name="lobHandler" ref="lobHandler"/>
  </bean>

 提示: 指定lobHandler时,对于MySQL、DB2、MS SQL Server、Oracle 10g,使用DefaultLobHandler即可,而Oracle 9i,
则可以使用OracleLobHandler。因为Oracle9i处理lob的方式和不太一样,所以这里要用spring提供的SimpleNativeJdbcExtractor.处理Oracle9i lob类型的特殊声明:

<bean id="nativeJdbcExtractor" lazy-init="true"  class="org.springframework.jdbc.support.nativejdbc.
SimpleNativeJdbcExtractor"/>

<bean id="lobHandler" lazy-init="true"   class="org.springframework.jdbc.support.lob.OracleLobHandler">
        <property name="nativeJdbcExtractor">
            <ref bean="nativeJdbcExtractor"/>
        </property>
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
  
 <!-- 为处理Blob类型字段的句柄声明 -->
 <property name="lobHandler">
  <ref local="lobHandler" />
 </property>
</bean>(配置在spring的xml下sessionfactory配置下)

同时还应该使用对应的JDBC驱动。

Clob字段定义:<property name="属性名" column="列名" type="org.springframework.orm.hibernate.support.ClobStringType"
 length="1048"/>这里的length是指字节,最大可以到2G.该字段在java对象中声明为String类型。

     如果使用的是mysql数据库其默认的上传文件大小只有1047552字节:如果上传的文件大于1047552字节则会出现异常
org.springframework.jdbc.UncategorizedSQLException: You can change this value on the server by setting
the max_allowed_packet' variable.根据提示可以修改mysql数据库的max_allowed_packet属性大小。
打开my.ini文件中找到# SERVER SECTION后在port=3306下面加上max_allowed_packet=?M 修改完后重启mysql服务即可成功上传。

<html:form method="post" action="/Action.do" enctype="multipart/form-data"> </html:form>

分享到:
评论

相关推荐

    oracle中使用jdbc读写clob和blob字段

    CLOB 和 BLOB 是 Oracle 中的 LOB(Large OBject)类型,它们可以存储大量的数据,最多可以容纳 4GB 的数据。下面我们将详细介绍如何使用 JDBC 读写 CLOB 和 BLOB 字段。 一、LOB 类型 LOB 类型分为 BLOB 和 CLOB ...

    ssh对lob完美处理

    java web 对clob大文本 blob图像处理 这是一个完整的例子,整合了ckeidtor,servlet直接显示数据库blob图片, 注意oracle驱动ojdbc14.jar,如果是其他驱动例如ojdbc14_*g都是不可以的。 表结构看hbm.xml配置文件 ...

    使用SSH构建Web应用系统

    1. **LOB字段处理**:SSH提供了处理大对象(LOB)字段的方法,如BLOB和CLOB,确保大数据类型的存储和检索。 2. **文件上传**:SSH框架支持文件上传,通常通过Struts2的上传组件实现,需要注意文件大小限制和安全性...

    ssh(structs,spring,hibernate)框架中的上传下载

     文件数据存储在Blob类型的FILE_CONTENT表字段上,在Spring中采用OracleLobHandler来处理Lob字段(包括Clob和Blob),由于在程序中不需要引用到oracle数据驱动程序的具体类且屏蔽了不同数据库处理Lob字段方法上的...

    ssh之plsql编程

    - **LOB数据类型**:用于存储大对象,如BLOB(二进制大对象)、CLOB(字符大对象)等。 - **属性类型**: - `%type`:定义一个变量,其数据类型与另一个已定义的数据类型相同。 - `%rowtype`:返回一个记录类型,...

    oracle基础练习.docx

    Oracle提供多种数据类型,如CHAR、VARCHAR2、NUMBER、DATE以及LOB(包括BLOB和CLOB)。日期格式可以使用TO_DATE函数转换,例如`to_date('2016-6-1','yyyy-MM-dd')`,或者直接使用DATE'2016-6-1'。 分析函数如RANK()...

    Oracle数据库的基础使用

    Oracle支持多种数据类型,如CHAR、VARCHAR2、NUMBER、DATE以及LOB(BLOB和CLOB)等。 在Oracle中执行SQL语句时,应谨慎处理事务,确保及时提交。此外,使用PL/SQL Developer等工具可以方便地查看表、描述表结构、...

Global site tag (gtag.js) - Google Analytics