`
blueram
  • 浏览: 763503 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

JAVA完全控制Oracle中BLOB、CLOB说明

阅读更多
JAVA完全控制Oracle中BLOB、CLOB说明 
原文出处:http://hi.baidu.com/elongskyscj/blog/item/7056d7dc71c5b5a0cc116656.html


网络上很多关于JAVA对Oracle中BLOB、CLOB类型字段的操作说明,有的不够全面,有的不够准确,甚至有的简直就是胡说八道。最近的项目正巧用到了这方面的知识,在这里做个总结。
环境:
Database: Oracle 9i
App Server: BEA Weblogic 8.14
表结构:
CREATE TABLE TESTBLOB (ID Int, NAME Varchar2(20), BLOBATTR Blob)
CREATE TABLE TESTBLOB (ID Int, NAME Varchar2(20), CLOBATTR Clob)
JAVA可以通过JDBC,也可以通过JNDI访问并操作数据库,这两种方式的具体操作存在着一些差异,由于通过App Server的数据库连接池JNDI获得的数据库连接提供的java.sql.Blob和java.sql.Clob实现类与JDBC方式提供的不同,因此在入库操作的时候需要分别对待;出库操作没有这种差异,因此不用单独对待。

一、BLOB操作
1、入库
(1)JDBC方式
     //通过JDBC获得数据库连接
     Class.forName("oracle.jdbc.driver.OracleDriver");
     Connection con = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:testdb", "test", "test");
     con.setAutoCommit(false);
     Statement st = con.createStatement();
     //插入一个空对象empty_blob()
     st.executeUpdate("insert into TESTBLOB (ID, NAME, BLOBATTR) values (1, "thename", empty_blob())");
     //锁定数据行进行更新,注意“for update”语句
     ResultSet rs = st.executeQuery("select BLOBATTR from TESTBLOB where ID=1 for update");
     if (rs.next())
     {
         //得到java.sql.Blob对象后强制转换为oracle.sql.BLOB
         oracle.sql.BLOB blob = (oracle.sql.BLOB) rs.getBlob("BLOBATTR");
         OutputStream outStream = blob.getBinaryOutputStream();
         //data是传入的byte数组,定义:byte[] data
         outStream.write(data, 0, data.length);
     }
     outStream.flush();
     outStream.close();
     con.commit();
     con.close();
(2)JNDI方式
     //通过JNDI获得数据库连接
     Context context = new InitialContext();
     ds = (DataSource) context.lookup("ORA_JNDI");
     Connection con = ds.getConnection();
     con.setAutoCommit(false);
     Statement st = con.createStatement();
     //插入一个空对象empty_blob()
     st.executeUpdate("insert into TESTBLOB (ID, NAME, BLOBATTR) values (1, "thename", empty_blob())");
     //锁定数据行进行更新,注意“for update”语句
     ResultSet rs = st.executeQuery("select BLOBATTR from TESTBLOB where ID=1 for update");
     if (rs.next())
     {
         //得到java.sql.Blob对象后强制转换为weblogic.jdbc.vendor.oracle.OracleThinBlob(不同的App Server对应的可能会不同)
         weblogic.jdbc.vendor.oracle.OracleThinBlob blob = (weblogic.jdbc.vendor.oracle.OracleThinBlob) rs.getBlob("BLOBATTR");
         OutputStream outStream = blob.getBinaryOutputStream();
         //data是传入的byte数组,定义:byte[] data
         outStream.write(data, 0, data.length);
     }
     outStream.flush();
     outStream.close();
     con.commit();
     con.close();
2、出库
     //获得数据库连接
     Connection con = ConnectionFactory.getConnection();
     con.setAutoCommit(false);
     Statement st = con.createStatement();
     //不需要“for update”
     ResultSet rs = st.executeQuery("select BLOBATTR from TESTBLOB where ID=1");
     if (rs.next())
     {
         java.sql.Blob blob = rs.getBlob("BLOBATTR");
         InputStream inStream = blob.getBinaryStream();
         //data是读出并需要返回的数据,类型是byte[]
         data = new byte[input.available()];
         inStream.read(data);
         inStream.close();
     }
     inStream.close();
     con.commit();
     con.close();
二、CLOB操作
1、入库
(1)JDBC方式
     //通过JDBC获得数据库连接
     Class.forName("oracle.jdbc.driver.OracleDriver");
     Connection con = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:testdb", "test", "test");
     con.setAutoCommit(false);
     Statement st = con.createStatement();
     //插入一个空对象empty_clob()
     st.executeUpdate("insert into TESTCLOB (ID, NAME, CLOBATTR) values (1, "thename", empty_clob())");
     //锁定数据行进行更新,注意“for update”语句
     ResultSet rs = st.executeQuery("select CLOBATTR from TESTCLOB where ID=1 for update");
     if (rs.next())
     {
         //得到java.sql.Clob对象后强制转换为oracle.sql.CLOB
         oracle.sql.CLOB clob = (oracle.sql.CLOB) rs.getClob("CLOBATTR");
         Writer outStream = clob.getCharacterOutputStream();
         //data是传入的字符串,定义:String data
         char[] c = data.toCharArray();
         outStream.write(c, 0, c.length);
     }
     outStream.flush();
     outStream.close();
     con.commit();
     con.close();
(2)JNDI方式
     //通过JNDI获得数据库连接
     Context context = new InitialContext();
     ds = (DataSource) context.lookup("ORA_JNDI");
     Connection con = ds.getConnection();
     con.setAutoCommit(false);
     Statement st = con.createStatement();
     //插入一个空对象empty_clob()
     st.executeUpdate("insert into TESTCLOB (ID, NAME, CLOBATTR) values (1, "thename", empty_clob())");
     //锁定数据行进行更新,注意“for update”语句
     ResultSet rs = st.executeQuery("select CLOBATTR from TESTCLOB where ID=1 for update");
     if (rs.next())
     {
         //得到java.sql.Clob对象后强制转换为weblogic.jdbc.vendor.oracle.OracleThinClob(不同的App Server对应的可能会不同)
         weblogic.jdbc.vendor.oracle.OracleThinClob clob = (weblogic.jdbc.vendor.oracle.OracleThinClob) rs.getClob("CLOBATTR");
         Writer outStream = clob.getCharacterOutputStream();
         //data是传入的字符串,定义:String data
         char[] c = data.toCharArray();
         outStream.write(c, 0, c.length);
     }
     outStream.flush();
     outStream.close();
     con.commit();
     con.close();
2、出库
     //获得数据库连接
     Connection con = ConnectionFactory.getConnection();
     con.setAutoCommit(false);
     Statement st = con.createStatement();
     //不需要“for update”
     ResultSet rs = st.executeQuery("select CLOBATTR from TESTCLOB where ID=1");
     if (rs.next())
     {
         java.sql.Clob clob = rs.getClob("CLOBATTR");
         Reader inStream = clob.getCharacterStream();
         char[] c = new char[(int) clob.length()];
         inStream.read(c);
         //data是读出并需要返回的数据,类型是String
         data = new String(c);
         inStream.close();
     }
     inStream.close();
     con.commit();
     con.close();
需要注意的地方:
1、java.sql.Blob、oracle.sql.BLOB、weblogic.jdbc.vendor.oracle.OracleThinBlob几种类型的区别
2、java.sql.Clob、oracle.sql.CLOB、weblogic.jdbc.vendor.oracle.OracleThinClob几种类型的区别 

 

分享到:
评论

相关推荐

    Oracle导出Clob,Blob工具

    在描述中提到的“Oracle导出Clob,Blob等大字段工具”就是为了解决这个问题而设计的,它是一个自编写的实用程序,方便用户导出和管理Oracle数据库中的大对象数据。 Oracle数据库中的Clob类型用于存储大量的文本数据...

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

    在数据库管理中,存储非结构化数据...综上所述,`CLOB`和`BLOB`都是在Oracle中存储图片的有效方法,具体选择哪种方式取决于应用场景和需求。`ClobAndBlob`工具提供了一种便捷的方式来体验和比较这两种方式的使用效果。

    oracle中的Blob和Clob区别

    ### Oracle中的BLOB和CLOB的区别 在Oracle数据库中,`BLOB`(Binary Large Object)和`CLOB`(Character Large Object)是用于存储大量数据的两种特殊数据类型。这两种类型都属于`LOB`(Large Object)类别,主要...

    clob-blob.rar_blob and clob_clob_java CLOB_java oracle cl_oracle

    对于CLOB和BLOB字段,Oracle JDBC驱动提供了`oracle.jdbc.driver.OracleClob`和`oracle.jdbc.driver.OracleBlob`类,它们实现了Java的标准接口`java.sql.Clob`和`java.sql.Blob`。这两个接口提供了读取和写入大数据...

    批量导出ORACLE数据库BLOB字段生成图片

    Oracle数据库在存储大对象(BLOB)数据时,提供了高效且灵活的方式,使得二进制数据如图片、文档等能够安全地保存在数据库中。批量导出Oracle数据库中的BLOB字段生成图片,是一项常见的需求,尤其对于那些需要将...

    oracle Blob Clob 大数处理 代码

    以上是Oracle Blob和Clob处理的一些核心知识点,实际应用中还需要结合具体的编程语言(如Java, PL/SQL等)和框架来编写代码实现文件上传下载、大数操作等功能。在处理大对象时,需要充分考虑性能、存储和安全等因素...

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

    这个过程通常涉及到Blob和Clob数据类型,它们是Java中的两种特殊对象,用于存储大对象(LOB)。Blob用于存储二进制数据,如图片、音频或视频文件,而Clob则用于存储字符数据,比如长文本。以下是如何使用Java处理...

    sql server中的image类型的数据导出到oracle的clob字段中

    我们使用了 Java 语言和 JDBC 驱动程序来实现数据的导出,并将 Image 类型数据写到文件中,然后将文件中的数据读取出来,并将其设置到 Oracle 的 CLOB 字段中。这种方法可以帮助我们实现不同数据库管理系统之间的...

    oracle中的BLOB(照片)转换到mysql中

    1. **查询BLOB数据**:使用SQL查询语句从Oracle数据库中选择含有BLOB字段的照片记录。例如: ```sql SELECT photo_blob FROM photos WHERE id = ; ``` 这里`photo_blob`是BLOB类型的列,`<photo_id>`是你想获取...

    读取oracle数据库中clob字段的值

    `getCharacterStream()`方法返回一个输入流,可以用来读取CLOB中的字符数据。 ```java Reader reader = clob.getCharacterStream(); ``` 3. **读取内容**: 使用`BufferedReader`来逐行读取CLOB中的内容,并将...

    Mybatis 处理 CLOB、BLOB 类型数据

    在 Oracle 数据库中,BLOB 类型对应的数据库类型是 BLOB,在 MySQL 中对应的类型是 BLOB。 MyBatis 提供了对 CLOB 和 BLOB 类型的内置支持,通过将 CLOB 类型映射到 Java 的 String 类型,BLOB 类型映射到 byte[] ...

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

    以下是对Oracle中Clob和Blob数据存取的Java代码示例及详细解释。 首先,确保你的项目已经引入了Oracle JDBC驱动(如ojdbc.jar)。然后,你需要创建一个与Oracle数据库的连接,这通常通过`DriverManager.get...

    JAVA对clob的操作

    然而,网络上关于JAVA对Oracle中BLOB、CLOB类型字段的操作说明往往不够全面、不够准确,甚至有的简直就是胡说八道。因此,本文旨在总结JAVA对Oracle中BLOB、CLOB类型字段的操作,包括入库和出库操作的实现细节。 一...

    文件上传至oracle blob字段的java实现

    指定文件夹下的所有文件上传至oracle的blob字段,java实现

    load blob clob

    本篇文章将围绕"load blob clob"这一主题,结合anysql免费工具合集,详细介绍如何在Oracle中操作Blob和Clob字段,并分享一些实用技巧。 首先,Blob数据类型在Oracle中代表Binary Large Object,它可以存储任意形式...

    Oracle bolb转换Base64 CLOB.txt

    Oracle slq bolb转换Base64 CLOB

    Hibernate对BLOB CLOB操作

    在Java的持久化框架Hibernate中,BLOB和CLOB是用来处理大数据对象(Binary Large Object和Character Large Object)的。这两个类型常用于存储图像、视频、大文本等数据,因为它们可以容纳超过数据库标准列大小限制的...

    weblogic.jdbc.wrapper.Clob_oracle_sql_CLOB 类型转换解决办法

    在使用 WebLogic 服务器进行应用程序开发时,尤其是在处理 Oracle 数据库中的 CLOB 类型数据时,开发者可能会遇到类型转换的问题。本文将详细介绍如何通过反射机制来解决 WebLogic 环境下 Oracle CLOB 类型转换成 `...

    Oracle clob和blob在jdbc的应用

    在Java编程中,Oracle数据库提供了对大型对象(Large Object)的支持,包括CLOB(Character Large Object)和BLOB(Binary Large Object)。这两种类型用于存储大量的文本数据(CLOB)和二进制数据(BLOB),例如...

Global site tag (gtag.js) - Google Analytics