`

Oracle数据库BLOB字段的存取

阅读更多

 最近几次碰到这个问题,需求是将一个文件或者文件流存储到Oracle数据库里,
Oracle提供了Blob和Clob用来存储二进制大对象数据,可是它和Java.sql.里面的Blob
不兼容,经常导致Blob字段无法锁定或者操作失败,总之我总结了一些经验
大家共享
首先建立测试数据表

 drop table filelist;
 commit;
 
 CREATE TABLE SYSTEM.FILELIST ( 
 "FILENAME" VARCHAR2(50) NOT NULL,
 "FILESIZE" NUMBER(20)  NULL, 
 "FILEBODY" BLOB  NULL,  
 PRIMARY KEY("FILENAME"), UNIQUE("FILENAME")) ;
 commit;



        测试过程,首先将硬盘文件读入数据库,然后再读出到硬盘的另一个新文件里,原码如下:


 

import java.io.*;
import java.util.*;
import java.sql.*;
import oracle.sql.*;
import oracle.jdbc.driver.*;
import java.text.*;

public class test
{
 public static void main(String args[]) throws java.io.IOException,java.sql.SQLException
 {
  dbBean db1=new dbBean(); 
  /**
  *这里是我的数据联接Bean
  *大家可以用自己的连接Bean
  */
  byte a[]=null;//**将测试文件test.doc读入此字节数组
  java.io.FileInputStream fin=null;
  java.io.FileOutputStream fout=null;
  oracle.jdbc.OracleResultSet ors=null;//**这里rs一定要用Oracle提供的
  oracle.jdbc.driver.OraclePreparedStatement opst=null;//**PreparedStatement用

                                                                              //Oracle提供的
   
  try
  {
   
   java.io.File f1=new java.io.File("c:/temp/test.doc");
   java.io.File f2=new java.io.File("c:/temp/testout.doc");//**从BLOB读出的信息写

                                                                 //入该文 件,和源文件对比测试用
   fin=new java.io.FileInputStream(f1);
   fout=new java.io.FileOutputStream(f2);
   
   
   int flength=(int)f1.length();//**读入文件的字节长度
   System.out.println("file length::"+flength);
   a=new byte[flength];
   
   int i=0;int itotal=0;
   /**将文件读入字节数组
   for (;itotal<flength;itotal=i+itotal )
  {
    
    i=fin.read(a,itotal,flength-itotal);
    
   }
   fin.close();
   
   System.out.println("read itotal::"+itotal);
  /**注意Oracle的 BLOB一定要用EMPTY_BLOB()初始化 
  String mysql="insert into filelist (FileName,FileSize,FileBody) values (?,?,EMPTY_BLOB())";
  opst=(oracle.jdbc.driver.OraclePreparedStatement)db1.conn.prepareStatement(mysql);
         opst.setString(1,"wordtemplate");
           opst.setInt (2,flength);
         opst.executeUpdate();
         opst.clearParameters();
         /**插入其它数据后,定位BLOB字段
           mysql="select filebody from filelist where filename=?";
           opst=(oracle.jdbc.driver.OraclePreparedStatement)db1.conn.prepareStatement(mysql);
           opst.setString(1,"wordtemplate");
           ors=(oracle.jdbc.OracleResultSet)opst.executeQuery();
           if (ors.next())
           {
           
           oracle.sql.BLOB blob=ors.getBLOB(1);/**得到BLOB字段           
           int j=blob.putBytes(1,a);/**将字节数组写入BLOB字段
           System.out.println("j:"+j);
                      
           db1.conn.commit();
           ors.close();
           }         
           
     System.out.println("insert into ok");
     
    byte b[]=null;/**保存从BLOB读出的字节
    opst.clearParameters();
           mysql="select filebody from filelist where filename=?";
           opst=(oracle.jdbc.driver.OraclePreparedStatement)db1.conn.prepareStatement(mysql);
           opst.setString(1,"wordtemplate");
           ors=(oracle.jdbc.OracleResultSet)opst.executeQuery();
    if (ors.next())
           {
           oracle.sql.BLOB blob2=ors.getBLOB(1); 
           
           System.out.println("blob2 length:"+blob2.length());
           b=blob2.getBytes(1,flength);/**从BLOB取出字节流数据
           System.out.println("b length::"+b.length);
           db1.conn.commit();
           }  
           ors.close();
           /**将从BLOB读出的字节写入文件
           fout.write(b,0,b.length);
           fout.close();  
    
     System.out.println("write itotal::"+b.length);
                 
   
  }
  catch(Exception e)
  {
   System.out.println("errror :"+e.toString() );
   e.printStackTrace();
   
  }
  finally
  { /**关闭所有数据联接
   stmt.close();
   db1.closeConn();
  }
   

 

    } }     编译运行在TomCat下调试通过。     需要注意的是Blob存取的过程,一般先存入和BLOB相关的控制数据,如文件的名字,     然后查询定位BLOB字段,利用OracleBlob提供的方法:     public int putBytes(long pos,byte bytes[])     public byte[]  getBytes(long pos,byte bytes[])     或者利用     public OutputStream getBinaryOutputStream() throws SQLException     public InputStream  getBinaryStream() throws SQLException    因为利用输入输出流总归还是利用到字节数组缓冲流,所以就不举例子了。

 

分享到:
评论

相关推荐

    oracle存取图片blob字段

    oracle 存读数据库的blob字段 .net有两种方式向Oracle的blob字段中存储图片:

    基于.NET的Oracle BLOB数据高效存取方法.pdf

    标题提到的“基于.NET的Oracle BLOB数据高效存取方法”是一种针对Oracle数据库中BLOB类型数据存储和读取的优化策略。BLOB(Binary Large Object)是Oracle数据库中用于存储大量二进制数据的对象,常用于保存图像、...

    jdbc+hibernate存取blob字段

    本篇将详细介绍如何使用JDBC(Java Database Connectivity)与Hibernate框架来操作Oracle数据库中的BLOB字段。 首先,Oracle数据库的BLOB字段提供了对大对象的高效存储,它的性能优于LONG字段,尤其适合存储大容量...

    Oracle,Clob,Blob数据存取的Java代码

    假设我们有一个包含BLOB字段的表`test_blob`: ```java String insertBlobSql = "INSERT INTO test_blob(id, blob_data) VALUES (?, ?)"; String selectBlobSql = "SELECT blob_data FROM test_blob WHERE id = ?";...

    Java存取OracleBlob字段,图片存储,Blob和BLOB的问题,Clob,oracle.docx

    Java存取OracleBlob字段,图片存储,Blob和BLOB的问题,Clob,oracle

    Struts2,Hibernate3,Spring2实现oracle存取blob字段(图片等二进制文件)(原来2分的,现在免费了!!给评分哦!!)

    Struts2,Hibernate3,Spring2实现oracle存取blob字段(图片等二进制文件) Myeclipse6.0下开发 哈哈,原来2分的,现在免费了!!!!!!!!!!!!!!!!!!!!!!!!给评分哦!!!!!!!!!!!!!!!!

    图片存入Oracle中,用clob和blob两种方式

    在数据库管理中,存储非结构化数据如图片、音频或视频文件时,通常会使用`CLOB`(Character Large Object)和`BLOB`(Binary Large Object)这两种数据类型。Oracle数据库系统支持这两种数据类型,用于存储大量文本...

    oracle,weblogic读写blob

    Oracle 和 WebLogic 服务器在处理 BLOB(Binary Large Object)数据类型时,涉及的是数据库管理和Web应用程序中的数据存储与检索。BLOB 类型通常用于存储大量二进制数据,如图片、音频或视频文件。本篇文章将深入...

    Oracle在PB中用OLE存取blob类型数据[归类].pdf

    "Oracle在PB中用OLE存取blob类型数据" Oracle是在PowerBuilder(PB)中使用OLE存取Blob类型数据的解决方案。该解决方案主要涉及到PB中使用OLE存取Blob类型数据的方法,包括建立数据库表、创建PB库、设置数据库连接...

    Excel文件在Oracle上的存取技术.pdf

    为了解决这些问题,他提出了将Excel文件直接存储在Oracle数据库的BLOB字段中的方案。 Oracle的BLOB类型允许存储高达4GB的二进制数据,适合Excel文件的存储需求。然而,由于BLOB数据的特殊性,不能像普通字段那样...

    关于在Hibernate中对于Clob,Blob字段的处理方法

    在Java的持久化框架Hibernate中,处理大数据类型如...通过以上方法,开发者可以在Hibernate中有效地处理Oracle数据库中的Clob和Blob字段。了解并熟练运用这些技术,能帮助我们构建高效、稳定且易于维护的数据存储系统。

    C#在oracle中存取图片(web版)

    描述还提到了SQL文件,这可能是用来创建存储图片的Oracle表的脚本,通常包含创建表的语句,定义字段,尤其是BLOB字段,用于存储图片。 "两个页面"指的可能是一个Web应用程序,包括一个用于上传图片的界面和一个用于...

    oracle 资料--图片存取

    在"Oracle图片存取"中,我们可以使用PL/SQL包,如DBMS_LOB,来执行读取、写入和处理BLOB字段的操作。DBMS_LOB包含了一系列的子程序,如BULK COLLECT INTO,用于批量处理BLOB数据,以及OPEN、READ和WRITE等函数,用于...

    DELPHI BLOB存取(ADO,ODAC)

    在Delphi编程环境下,我们可以使用两种主要的数据访问技术来操作BLOB字段:ADO(ActiveX Data Objects)和ODAC(Object Data Access Components)。下面将详细探讨这两种方法。 1. **ADO(ActiveX Data Objects)**...

    Word文件在Oracle中存取技术的设计与实现.pdf

    在Oracle中定义BLOB字段后,可以通过特定的API和方法来读写这些字段中的数据。 在VB6中,可以利用ADO(ActiveX Data Objects)的Field对象的GetChunk和AppendChunk方法来操作BLOB字段。GetChunk方法允许分块读取...

    mysql,sqlserver,oracle三种数据库的大对象存取解析.docx

    OracleBlob blob = new OracleBlob(); blob.setBinaryStream(0); int length = (int) in.getChannel().size(); blob.setBytes(1, new byte[length], 0, length); cs.setBlob(2, blob); cs.execute(); ``` 总结来说...

    BLOB数据存取

    BLOB是数据库中的一个特殊字段,用于存储大容量的二进制数据。根据数据的大小,BLOB通常分为四种类型:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB,分别对应不同的存储限制。 3. **VC++与ADO的集成** 在VC++项目中,...

    DELPHI存取JPEG、BMP图像到数据库完整解决方案

    综上所述,DELPHI存取JPEG、BMP图像到数据库的完整解决方案涉及图像读取、转换、数据库连接、BLOB字段操作等多个环节。在实际开发中,根据项目需求和性能要求,可以选择合适的方法和技术进行组合,确保图像数据的...

    在ORACLE数据库中如何对多媒体数据对象进行处理.pdf

    特别地,PL/SQL是Oracle数据库的内置脚本语言,DBMS_LOB包提供了丰富的函数和过程,用于对BLOB、CLOB、NCLOB、BFILE和临时LOBs进行部分或全部数据的操作。这些方法大致可以分为五类:修改内部LOBs、读取或检查LOBs、...

    网页在Oracle中存取图片

    2. JDBC操作:使用Java的JDBC驱动程序,将图片数据插入到Oracle数据库的BLOB字段中。涉及SQL语句执行,以及PreparedStatement的setBinaryStream方法或setBlob方法。 三、图片从数据库取出 1. 查询图片:通过SQL查询...

Global site tag (gtag.js) - Google Analytics