怎么把大于32767的CLOB或者BLOB写入到文件中

怎么把大于32767的CLOB或者BLOB写入到文件中,第1张

EMPTY_BLOB()和EMPTY_CLOB()函数是用来对大数据空销卖类型字段进行初始化 *** 作斗贺的。

INSERT INTO 表(file_name,file_blob) VALUES ("文件名",EMPTY_BLOB())

或斗逗

INSERT INTO 表(file_name,file_blob) VALUES ("文件名",EMPTY_BLOB())

RETURNING file_blob INTO dst_file----dst_file是与file_blob对应的变量。

select file_name,dbms_lob.getlength(file_blob) si_ze from 表

EMPTY_CLOB()与EMPTY_BLOB()类同。

在spring中采用OracleLobHandler来处理oracle大字段(包括clob和blob),则在程序中裤衫不需要引用oracle的特殊类,从而能够保证支持代码支持多数据库。

在Spring的主配置文件xx.xml中的配置SessionFactory的bean中配置:

<bean id="nativeJdbcExtractor"

class="org.springframework.jdbc.support.nativejdbc.CommonsDbcpNativeJdbcExtractor"

lazy-init="true" autowire="default" dependency-check="default"/>

<bean id="oracleLobHandler"

class="org.springframework.jdbc.support.lob.OracleLobHandler"

lazy-init="true" autowire="default" dependency-check="default">

<property name="nativeJdbcExtractor" ref="nativeJdbcExtractor"/>

</bean>

<bean id="sessionFactory"

class="org.hibernate.cfg.SWSSessionFactoryBean" lazy-init="false"

autowire="default" dependency-check="default">

...

<慧陵property name="lobHandler">

<ref bean="oracleLobHandler"/>

</property>

...

</bean>

nativeJdbcExtractor和 lobHandler 设置为 lazy-init="true",

因为 nativeJdbcExtractor需要通过运行期的反射机制获取底层的 JDBC 对象,

所以需要避免在 Spring 容器启动时就实例化这两个 Bean。

<注:上面的SWSSessionFactoryBean是被重写过的胡碧腔,继承AnnotationSessionFactoryBean>

1、首先数据表中的clob类型对应java持久化类的String类型;而blob类型对应byte[]类型

2、1.定义

hibernate标签时,持久化类中对应clob类型的属性的hibernate

type应为org.springframework.orm.hibernate.support.ClobStringType;而对应blob类型

的属性的hibernate

type应为org.springframework.orm.hibernate.support.BlobByteArrayType。

2.如果通过spring 注解功能配置PoJo类时,在该大字段属性的getXXX()方法前面加上注解:

public String xxx

...

@Lob

@Type(type="org.springframework.orm.hibernate3.support.ClobStringType")

@Column(length=10000)

public String getXXX ()

{

return xxx

}

读兄兆态出文件的二进制数据byte[]:

FileStream fs = new ....

bytep[] bfile = new byte[(int)fs.Length]

fs.Read(bfile,0,bfile.Length)

fs.Close()

以上是个大概的读取文件二羡源进制过程,自己完善下

然后:

OracleParameter para = new OracleParameter()

para.Value = bFile

para.OracleType = OracleType.Clob

设置好参数,接着就是普通的:

cmd = new OracleCommand("insert into ....", conn)

cmd.Paramenters.Add(para)

cmd.ExecuteNonQuery()

...相信你也看出了,和普通的插猜族入没什么两样嘛.

读取也差不多:

byte[] bfile = (byte[])resultReader["file"]

这样就有了二进制数据了,接着把这个数据写进文件里:

FileStream fs = new ...

fs.Write(fbile,0,bfile.Length)

fs.Close()

.....

总之,你懂的...


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12204256.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存