JDBC4.0插入blob真方便

今天试用了一下oracle的支持JDBC4.0标准的客户端ojdbc6.jar,发现用了这个之后,插入blob字段变得简单多了。

以前如果想向oracle数据库里插入一个blob的字段,需要先执行一条insert语句,插入个empty_blob,然后再select for update,取出来之后把Blob字段cast成oracle自己的BLOB类型,然后调用BLOB的setBinaryStream()方法获得一个OutputStream,再向这个OutputStream中写入内容,最后再提交,这种方法的介绍网上到处都是,不用多说。

现在有了JDBC4.0,这个过程变简单了许多,调用Connection的createBlob()方法创建一个Blob对象,调用Blob对象的setBinaryStream()方法获得一个OutputStream,再向这个OutputStream中写入内容,然后直接把Blob写入到数据库里就行了。

Blob blob = conn.createBlob();
            OutputStream out = blob.setBinaryStream(0);
            byte[] temp = new byte[4096];
            int length;
            while ((length = is.read(temp)) != -1) {
                out.write(temp, 0, length);
            }

PreparedStatement pstmt = conn
					.prepareStatement("insert into t_blob_test(name,content) values(?,?)");
			pstmt.setString(1, "name2");
            pstmt.setBlob(2, blob);
			pstmt.executeUpdate();


你可能感兴趣的:(oracle)