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

Oracle中的BLOB和CLOB

阅读更多

一、区别和定义

      LONG: 可变长的字符串数据,最长2G,LONG具有VARCHAR2列的特性,可以存储长文本一个表中最多一个LONG列
  LONG RAW: 可变长二进制数据,最长2G
  CLOB:  字符大对象Clob 用来存储单字节的字符数据
  NCLOB: 用来存储多字节的字符数据
  BLOB: 用于存储二进制数据
  BFILE: 存储在文件中的二进制数据,这个文件中的数据只能被只读访。但该文件不包含在数据库内。

        bfile字段实际的文件存储在文件系统中,字段中存储的是文件定位指针.bfile对oracle来说是只读的,也不参与事务性控制和数据恢复.
  
  CLOB,NCLOB,BLOB都是内部的LOB(Large Object)类型,最长4G,没有LONG只能有一列的限制

  要保存图片、文本文件、Word文件各自最好用哪种数据类型?
  --BLOB最好,LONG RAW也不错,但Long是oracle将要废弃的类型,因此建议用BLOB。

二、操作

1、 get

CLOB

 

java 代码
  1. //获得数据库连接   
  2.     Connection con = ConnectionFactory.getConnection();   
  3.     con.setAutoCommit(false);   
  4.     Statement st = con.createStatement();   
  5.     //不需要“for update”   
  6.     ResultSet rs = st.executeQuery("select CLOBATTR from TESTCLOB where ID=1");   
  7.     if (rs.next())   
  8.     {   
  9.         java.sql.Clob clob = rs.getClob("CLOBATTR");   
  10.         Reader inStream = clob.getCharacterStream();   
  11.         char[] c = new char[(int) clob.length()];   
  12.         inStream.read(c);   
  13.         //data是读出并需要返回的数据,类型是String   
  14.         data = new String(c);   
  15.         inStream.close();   
  16.     }   
  17.     inStream.close();   
  18.     con.commit();   
  19.     con.close();   
  20.    

 

BLOB
java 代码
  1. //获得数据库连接   
  2.     Connection con = ConnectionFactory.getConnection();   
  3.     con.setAutoCommit(false);   
  4.     Statement st = con.createStatement();   
  5.     //不需要“for update”   
  6.     ResultSet rs = st.executeQuery("select BLOBATTR from TESTBLOB where ID=1");   
  7.     if (rs.next())   
  8.     {   
  9.         java.sql.Blob blob = rs.getBlob("BLOBATTR");   
  10.         InputStream inStream = blob.getBinaryStream();   
  11.         //data是读出并需要返回的数据,类型是byte[]   
  12.         data = new byte[input.available()];   
  13.         inStream.read(data);   
  14.         inStream.close();   
  15.     }   
  16.     inStream.close();   
  17.     con.commit();   
  18.     con.close();   

 

2、 put

CLOB
java 代码
  1. //获得数据库连接   
  2.     Connection con = ConnectionFactory.getConnection();   
  3.     con.setAutoCommit(false);   
  4.     Statement st = con.createStatement();   
  5.     //插入一个空对象empty_clob()   
  6.     st.executeUpdate("insert into TESTCLOB (ID, NAME, CLOBATTR) values (1, "thename", empty_clob())");   
  7.     //锁定数据行进行更新,注意“for update”语句   
  8.     ResultSet rs = st.executeQuery("select CLOBATTR from TESTCLOB where ID=1 for update");   
  9.     if (rs.next())   
  10.     {   
  11.         //得到java.sql.Clob对象后强制转换为oracle.sql.CLOB   
  12.         oracle.sql.CLOB clob = (oracle.sql.CLOB) rs.getClob("CLOBATTR");   
  13.         Writer outStream = clob.getCharacterOutputStream();   
  14.         //data是传入的字符串,定义:String data   
  15.         char[] c = data.toCharArray();   
  16.         outStream.write(c, 0, c.length);   
  17.     }   
  18.     outStream.flush();   
  19.     outStream.close();   
  20.     con.commit();   
  21.     con.close();   
  22.   
BLOB
java 代码
  1. //获得数据库连接   
  2.     Connection con = ConnectionFactory.getConnection();   
  3.     con.setAutoCommit(false);   
  4.     Statement st = con.createStatement();   
  5.     //插入一个空对象empty_blob()   
  6.     st.executeUpdate("insert into TESTBLOB (ID, NAME, BLOBATTR) values (1, "thename", empty_blob())");   
  7.     //锁定数据行进行更新,注意“for update”语句   
  8.     ResultSet rs = st.executeQuery("select BLOBATTR from TESTBLOB where ID=1 for update");   
  9.     if (rs.next())   
  10.     {   
  11.         //得到java.sql.Blob对象后强制转换为oracle.sql.BLOB   
  12.         oracle.sql.BLOB blob = (oracle.sql.BLOB) rs.getBlob("BLOBATTR");   
  13.         OutputStream outStream = blob.getBinaryOutputStream();   
  14.         //data是传入的byte数组,定义:byte[] data   
  15.         outStream.write(data, 0, data.length);   
  16.     }   
  17.     outStream.flush();   
  18.     outStream.close();   
  19.     con.commit();   
  20.     con.close();   

 

 

 

 

 

 

分享到:
评论

相关推荐

    oracle(blob转换为clob)

    接下来,使用`DBMS_LOB.SUBSTR`按块读取BLOB数据,将其转换为`VARCHAR2`类型,再使用`DBMS_LOB.WRITEAPPEND`将转换后的数据写入到CLOB中。最后返回转换后的CLOB数据。 #### 4. 更新表中的数据 在实际应用中,一旦...

    oracle Blob转换Clob

    - 通过`DBMS_LOB.WRITE_APPEND`方法将转换后的数据追加到临时Clob中。 4. **返回转换后的Clob**: - 函数最终返回整个转换后的Clob数据。 #### 知识点五:注意事项 - **性能考虑**:对于非常大的Blob数据,这种...

    oracle中的Blob和Clob区别

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

    BLOB和CLOB的区别以及在ORALCE中的插入和查询操作

    了解BLOB和CLOB的区别以及如何在Oracle中进行插入和查询操作对于数据库开发者和管理员来说至关重要。 首先,我们来看BLOB和CLOB的主要区别: 1. 数据类型:BLOB用于存储二进制大对象,如图片、视频、音频文件或者...

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

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

    Oracle导出Clob,Blob工具

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

    如何将DB2数据库中的大对象(BLOB,CLOB)数据类型复制到Oracle数据库中

    在数据库迁移或数据同步的过程中,有时需要将含有大对象(LOB,包括BLOB和CLOB)的数据从一个数据库系统复制到另一个不完全支持LOB的数据库系统。本例中,我们讨论如何将DB2数据库中的BLOB数据类型复制到Oracle...

    mysql和Oracle在对clob和blob字段的处理

    - 存储机制:MySQL的`TEXT`和`BINARY`系列数据类型通常存储在数据页中,而Oracle的`CLOB`和`BLOB`可以存储在表空间中,允许更大的数据量。 - 索引支持:Oracle支持对`CLOB`和`BLOB`字段建立索引,而MySQL的索引...

    Oracle8i对Blob和Clob类型的操作

    在Oracle8i版本中,数据库支持了大型对象(LOB)类型,包括BLOB(Binary Large Object)和CLOB(Character Large Object)。这两种数据类型用于存储大量二进制数据(如图片、视频或文档)和文本数据(如长篇文章或...

    Oracle导出Clob,Blob工具版本2

    "Oracle导出Clob,Blob工具版本2" 是一个专为解决这个问题而设计的应用程序,它改进了对CLOB(Character Large Object)和BLOB(Binary Large Object)数据类型的导出效率,特别是修复了上一版本中导出时间过长的问题...

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

    这是因为 WebLogic 服务器为了更好地管理和操作数据库连接,会使用自己的包装类 `weblogic.jdbc.wrapper.Clob_oracle_sql_CLOB` 来表示 CLOB 类型的数据,而不是直接使用 Oracle 提供的标准 `oracle.sql.CLOB` 类。...

    Mybatis 处理 CLOB、BLOB 类型数据

    Mybatis 处理 CLOB、BLOB 类型数据 MyBatis 处理 CLOB、BLOB 类型数据是指在使用 MyBatis ...通过使用 MyBatis 处理 CLOB 和 BLOB 类型数据,可以方便地存储和读取大字段类型的数据,提高应用程序的性能和可扩展性。

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

    BLOB是一种可以存储大量二进制数据的对象,分为四种子类型:BLOB、CLOB、NCLOB和BFILE。在Oracle中,BLOB用于存储二进制数据,如照片;而在MySQL中,BLOB也有类似的分类,包括TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB...

    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中CLOB字段转String类型

    本文将详细介绍如何在Oracle中实现CLOB字段到字符串类型的转换,并探讨其中的关键技术和注意事项。 #### 一、CLOB概述 1. **定义**: - `CLOB`是Oracle数据库提供的一种特殊的数据类型,用于存储大文本数据。 - ...

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

    Oracle数据库在存储大对象...总之,批量导出Oracle数据库中的BLOB字段生成图片涉及到了数据库连接、SQL查询、BLOB数据处理和文件I/O等多个技术环节。掌握这些知识点对于管理和维护包含二进制数据的数据库系统至关重要。

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

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

    oracle Blob Clob 大数处理 代码

    在Oracle中,Blob和Clob的处理涉及到许多关键知识点,包括创建、读取、更新和删除大对象数据。以下是一些相关的详细说明: 1. **创建LOB字段**: 在创建表时,可以添加Blob或Clob字段来存储大对象。例如: ```sql...

    oracle对大对象类型操作:blob,clob,nclob,bfile

    Oracle数据库系统支持对大型数据对象(LOBs,Large Objects)的操作,这包括BLOB、CLOB、NCLOB和BFILE四种类型。每种类型都有其特定的用途和特性,适用于存储不同类型的大数据。 1. BLOB(Binary Large Object): ...

Global site tag (gtag.js) - Google Analytics