zoukankan      html  css  js  c++  java
  • Oracle中Blob和Clob

    Blob是指二进制大对象也就是英文Binary Large Object的所写;
    Clob是指大字符对象也就是英文Character Large Object的所写。
    因此这两个类型都是用来存储大量数据而设计的,其中BLOB是用来存储大量二进制数据的;CLOB用来存储大量文本数据。

    在JDBC中有两个接口对应数据库中的BLOB和CLOB类型,java.sql.Blob和java.sql.Clob。和你平常使用数据库一样你可以直接通过ResultSet.getBlob()方法来获取该接口的对象。与平时的查找唯一不同的是得到Blob或Clob的对象后,我们并没有得到任何数据,但是我们可以这两个接口中的方法得到数据。 
    例如: 
    Blob b=resultSet.getBlob(1); 
    InputStream bin=b.getBinaryStream(); 
    Clob c=resultSet.getClob(2); 
    Reader cReader=c.getCharacterStream(): 
     
    另外还有一种获取方法,不使用数据流,而是使用数据块。 
    例如 
    Blob b=resultSet.getBlob(1); 
    byte data=b.getByte(0,b.length()); 
    Clob c=resultSet.getClob(2); 
    String str=c.getSubString(0,c.length());
    在这里要说明一下,这个方法其实并不安全,如果你很细心的话,那很容易就能发现getByte()和getSubString()两个方法中的第二个参数都是int类型的,而BLOB和CLOB是用来存储大量数据的。而且Bolb.length()和Clob.length()的返回值都是long类型的,所以很不安全。

  • 相关阅读:
    Linux Shell中的延时函数
    调试core文件(转)
    C++类构造函数初始化列表(转)
    seq简介(转)
    查看内存使用情况(转)
    awk 数组实例(转)
    伪终端(转)
    C++类成员变量的初始化方法(转)
    几个shell命令(转)
    子进程自父进程继承什么或未继承什么(转)
  • 原文地址:https://www.cnblogs.com/kakaisgood/p/8027426.html
Copyright © 2011-2022 走看看