创建测试表
建表语句如下:
create table t_clob(
id varchar2(32) primary key,
clobfield CLOB
);
读取CLOB字段的代码示例
public void readClob() {
Connection conn = DbManager.getInstance().getConnection();
try {
PreparedStatement stat = conn.prepareStatement("select clobfield from t_clob where id ='1'");
ResultSet rs = stat.executeQuery();
if (rs.next()) {
oracle.sql.CLOB clob = (oracle.sql.CLOB) rs.getClob("clobfield");
String value = clob.getSubString(1, (int) clob.length());
System.out.println("CLOB字段的值:" + value);
}
conn.commit();
} catch (SQLException e) {
e.printStackTrace();
} finally {
DbManager.getInstance().closeConnection(conn);
}
}
写入CLOB字段的代码示例
public void writeClob() {
Connection conn = DbManager.getInstance().getConnection();
try {
conn.setAutoCommit(false);
PreparedStatement stat = conn.prepareStatement("insert into t_clob (id, clobfield) values(sys_guid(), ?)");
String clobContent = "This is a very very long string";
StringReader reader = new StringReader(clobContent);
stat.setCharacterStream(1, reader, clobContent.length());
stat.executeUpdate();
stat = conn.prepareStatement("select clobfield from t_clob where id='1' for update");
ResultSet rs = stat.executeQuery();
if (rs.next()) {
oracle.sql.CLOB clob = (oracle.sql.CLOB) rs.getClob("clobfield");
Writer outStream = clob.getCharacterOutputStream();
char[] c = clobContent.toCharArray();
outStream.write(c, 0, c.length);
outStream.flush();
outStream.close();
}
conn.commit();
} catch (SQLException | IOException e) {
e.printStackTrace();
}
DbManager.getInstance().closeConnection(conn);