oracle empty_clob,CLOB BLOB字段写入文本方法 EMPTY_CLOB()

在向带有Lob类型的字段加入数据时,

使用EMPTY_CLOB()初始化CLOB字段,

然后再使用输出流向字段中写数据(这些数据往往都是字节流量相对较大的).

CREATE TABLE article(

subject VARCHAR2(50 char),

content CLOB ,

tstamp TIMESTAMP DEFAULT SYSDATE

);

--使用EMPTY_CLOB()来初始化CLOB字段

String strSql = "INSERT INTO article(subject,content) VALUES('文章标题:Empty_clob()的使用方法',EMPTY_CLOB())";

Connection conn = db.getConnection();

conn.setAutoCommit(false);

PreparedStatement ptmt = conn.prepareStatement(sqlBuffer.toString());

ptmt.executeUpdate();

strSql = "select content from article where subject = "+subject+" for update ";

ResultSet rs = ptmt.executeQuery(strSql);

if (rs.next()) {

/* 取出此CLOB对象 */

oracle.sql.CLOB clob = null;

clob = (oracle.sql.CLOB) rs.getClob("content");

/* 向CLOB对象中写入数据 */

BufferedWriter out = new BufferedWriter(clob.getCharacterOutputStream());

out.write(content);

out.close();

out = null;

conn.commit();

}

学习到了。

2. 查询获取clob对象

3. 创建buferedwriter 对象 构成参数是 clob对象的strea流 也可以这样写

BufferedWriter out = new BufferedWriter(clob.setCharacterStream(clob.length()), 1024);

4. 然后 通过writer 进行writeer 最后 clsoe掉。 大文本就已经写入数据库字段了。

标签:CLOB,clob,content,字段,BLOB,EMPTY,out

来源: https://www.cnblogs.com/ives-xu/p/13853381.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中 BlobClob 是 JDBC API 中的两种数据类型,Blob 表示二进制数据,Clob 表示文本数据。InputStream 和 byte[] 则是 Java 中常用的二进制数据处理方式。 下面是 Blob 和 byte[] 之间的相互转换: 1. Blob 转 byte[] ```java Blob blob = resultSet.getBlob("blob_column"); byte[] data = blob.getBytes(1, (int) blob.length()); ``` 2. byte[] 转 Blob ```java byte[] data = ...; Blob blob = connection.createBlob(); blob.setBytes(1, data); ``` 下面是 Blob 和 InputStream 之间的相互转换: 1. Blob 转 InputStream ```java Blob blob = resultSet.getBlob("blob_column"); InputStream inputStream = blob.getBinaryStream(); ``` 2. InputStream 转 Blob ```java InputStream inputStream = ...; Blob blob = connection.createBlob(); OutputStream outputStream = blob.setBinaryStream(1); byte[] buffer = new byte[4096]; int bytesRead = -1; while ((bytesRead = inputStream.read(buffer)) != -1) { outputStream.write(buffer, 0, bytesRead); } ``` 下面是 BlobClob 之间的相互转换: 1. BlobClob ```java Blob blob = resultSet.getBlob("blob_column"); Clob clob = connection.createClob(); Writer writer = clob.setCharacterStream(1); InputStream inputStream = blob.getBinaryStream(); byte[] buffer = new byte[4096]; int bytesRead = -1; while ((bytesRead = inputStream.read(buffer)) != -1) { writer.write(new String(buffer, 0, bytesRead, "UTF-8")); } ``` 2. ClobBlob ```java Clob clob = resultSet.getClob("clob_column"); Blob blob = connection.createBlob(); OutputStream outputStream = blob.setBinaryStream(1); Reader reader = clob.getCharacterStream(); char[] buffer = new char[4096]; int charsRead = -1; while ((charsRead = reader.read(buffer)) != -1) { outputStream.write(new String(buffer, 0, charsRead).getBytes("UTF-8")); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值