好记性不如烂笔头20-java对oracle的clob和blob字段的总结
2015-02-03 17:15
323 查看
整体情况
CLOB字段在实际工作中,还是有很多的应用场景;但是BLOB字段在现在的大型系统中,作用越来越不尽如人意。
因为数据库资源,在大型系统中,升级成本是最高的;而BLOB字段中大量的数据,会给数据库造成严重的IO问题。如果我们购买几百万的小型机,就是为了存放几张普通图片,估计会被人把牙齿笑掉;虽然数据库有良好的认证系统,但是不代表用文件系统不能实现。
因此,如果是老的系统,如果我们不打算全面重构和升级,那么这个BLOB改用还是要用;如果是新的系统,原则上不推荐BLOB字段,实现的代价较高,并且操作繁琐。
通过JDBC操纵Oracle数据库的LOB字段,写入、修改、读取三种方式,掌握起来并不难。较之其它类型字段,有下面几个显著不同的特点:
1、必须取消自动提交
存取操作开始前,必须用setAutoCommit(false)取消自动提交。其它类型字段则无此特殊要求。这是因为存取LOB类型字段时,通常要进行多次操作可以完成。不这样的话,Oracle将抛出“读取违反顺序”的错误。
2、插入方式不同。
LOB数据不能象其它类型数据一样直接插入(INSERT)。插入前必须先插入一个空的LOB对象,CLOB类型 的空对象为EMPTY_CLOB(),BLOB类型的空对象为EMPTY_BLOB()。之后通过SELECT命令查询得到先前插入的记录并锁定,继而将 空对象修改为所要插入的LOB对象。
3、修改方式不同。
其它类型的字段修改时,用UPDATE … SET…命令即可。而LOB类型字段,则只能用SELECT … FOR UPDATE命令将记录查询出来并锁定,然后才能修改。且修改也有两种改法:一是在原数据基础上的修改(即覆盖式修改),执行SELECT … FOR UPDATE后再改数据;二是替换(先将原数据清掉,再修改),先执行UPDATE命令将LOB字段之值设为空的LOB对象,然后进行第一种改法。建议使用替换的方法,以实现与其它字段UPDATE操作后一样的效果。
4、存取时应使用由数据库JDBC驱动程序提供的LOB操作类。
对于Oracle数据库,应使用oracle.sql.CLOB和oracle.sql.BLOB。不使用由数据库JDBC驱动程序提供的LOB类时,程序运行时易于出现“抽象方法调用”的错误,这是因为JDBC所定义的java.sql.Clob与 java.sql.Blob接口,其中的一些方法并未在数据库厂家提供的驱动程序中真正实现。
5、存取手段与文件操作相仿。
对于BLOB类型,应用InputStream/OutputStream类,此类不进行编码转换,逐个字节存取。oracle.sql.BLOB类相应提供了getBinaryStream()和getBinaryOutputStream()两个方法,前一个 方法用于读取Oracle的BLOB字段,后一个方法用于将数据写入Oracle的BLOB字段。
对于CLOB类型,应用Reader/Writer类,此类进行编码转换。oracle.sql.CLOB类相应 提供了getCharacterStream()和getCharacterOutputStream()两个方法,前一个方法用于读取Oracle的 CLOB字段,后一个方法用于将数据写入Oracle的CLOB字段。
需要说明的是,为了大幅提高程序执行效率,对BLOB/CLOB字段的读写操作,应该使用缓冲操作类(带 Buffered前缀),即:BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter。
CLOB字段在实际工作中,还是有很多的应用场景;但是BLOB字段在现在的大型系统中,作用越来越不尽如人意。
因为数据库资源,在大型系统中,升级成本是最高的;而BLOB字段中大量的数据,会给数据库造成严重的IO问题。如果我们购买几百万的小型机,就是为了存放几张普通图片,估计会被人把牙齿笑掉;虽然数据库有良好的认证系统,但是不代表用文件系统不能实现。
因此,如果是老的系统,如果我们不打算全面重构和升级,那么这个BLOB改用还是要用;如果是新的系统,原则上不推荐BLOB字段,实现的代价较高,并且操作繁琐。
通过JDBC操纵Oracle数据库的LOB字段,写入、修改、读取三种方式,掌握起来并不难。较之其它类型字段,有下面几个显著不同的特点:
1、必须取消自动提交
存取操作开始前,必须用setAutoCommit(false)取消自动提交。其它类型字段则无此特殊要求。这是因为存取LOB类型字段时,通常要进行多次操作可以完成。不这样的话,Oracle将抛出“读取违反顺序”的错误。
2、插入方式不同。
LOB数据不能象其它类型数据一样直接插入(INSERT)。插入前必须先插入一个空的LOB对象,CLOB类型 的空对象为EMPTY_CLOB(),BLOB类型的空对象为EMPTY_BLOB()。之后通过SELECT命令查询得到先前插入的记录并锁定,继而将 空对象修改为所要插入的LOB对象。
3、修改方式不同。
其它类型的字段修改时,用UPDATE … SET…命令即可。而LOB类型字段,则只能用SELECT … FOR UPDATE命令将记录查询出来并锁定,然后才能修改。且修改也有两种改法:一是在原数据基础上的修改(即覆盖式修改),执行SELECT … FOR UPDATE后再改数据;二是替换(先将原数据清掉,再修改),先执行UPDATE命令将LOB字段之值设为空的LOB对象,然后进行第一种改法。建议使用替换的方法,以实现与其它字段UPDATE操作后一样的效果。
4、存取时应使用由数据库JDBC驱动程序提供的LOB操作类。
对于Oracle数据库,应使用oracle.sql.CLOB和oracle.sql.BLOB。不使用由数据库JDBC驱动程序提供的LOB类时,程序运行时易于出现“抽象方法调用”的错误,这是因为JDBC所定义的java.sql.Clob与 java.sql.Blob接口,其中的一些方法并未在数据库厂家提供的驱动程序中真正实现。
5、存取手段与文件操作相仿。
对于BLOB类型,应用InputStream/OutputStream类,此类不进行编码转换,逐个字节存取。oracle.sql.BLOB类相应提供了getBinaryStream()和getBinaryOutputStream()两个方法,前一个 方法用于读取Oracle的BLOB字段,后一个方法用于将数据写入Oracle的BLOB字段。
对于CLOB类型,应用Reader/Writer类,此类进行编码转换。oracle.sql.CLOB类相应 提供了getCharacterStream()和getCharacterOutputStream()两个方法,前一个方法用于读取Oracle的 CLOB字段,后一个方法用于将数据写入Oracle的CLOB字段。
需要说明的是,为了大幅提高程序执行效率,对BLOB/CLOB字段的读写操作,应该使用缓冲操作类(带 Buffered前缀),即:BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter。
相关文章推荐
- 好记性不如烂笔头18-java对Oracle的CLOB字段的操作
- Java操纵oracle的CLOB和BLOB字段
- 从 Oracle 大字段(blob,clob)的读、写认识 Java JDBC操作全攻略
- JAVA对Oracle中BLOB、CLOB类型字段的操作说明
- Oracle中的大字段 Blob/Clob
- JAVA完全控制Oracle中BLOB、CLOB说明
- Oracle函数小全||记录下来,用处多多啊——好记性不如烂笔头
- JAVA操作Oracle中CLOB字段
- 通过JDBC 操作 ORACLE BLOB,CLOB字段类型
- Oracle中BLOB和CLOB字段的操作
- Java 存储和读取 oracle CLOB 类型字段
- Java中读取Oracle中Clob字段的两种方法
- 同时写oracle的CLOB和BLOB字段的方法
- Hibernate操作Blob类型字段出现java.lang.AbstractMethodError: oracle.jdbc.driver.OracleResultSetImpl.getBlob(Ljava/lang/String;)Ljava/sql/
- oracle中的BLOB与CLOB字段更新时的行迁移与称链接
- java 操作ORACLE Clob字段
- 使用JAVA读取ORACLE BLOB字段实现上传下载
- 各位tx,有没有既能读写oracle8i的clob字段又能读写oracle9i的clob字段的java组件?
- JAVA读取Oracle中的blob图片字段并显示
- java对oracle中blob字段的操作