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类型的,所以很不安全。

  • 相关阅读:
    SpringBoot启动类踩坑
    数组作业
    多态的使用
    intellij idea怎么设置软件启动时选择项目进入
    方法的递归调用
    取一个数字数字后4位的和
    day09作业
    java 随机数
    java 方法
    java 循环作业
  • 原文地址:https://www.cnblogs.com/kakaisgood/p/8027426.html
Copyright © 2011-2022 走看看