clob字段的处理(oracle)
发表于:2007-07-01来源:作者:点击数:
标签:
先用PrepareStatement 对象插入( 这时一定要设定Connection对象的AutoCommit为false,即 conn.setAutoCommit(false); ),语句这样写: String sql = INSERT INTO flower_news (flower_news_id,news_content,news_author) VALUES (flower_news_id_s.nextval,em
先用PrepareStatement 对象插入(
这时一定要设定Connection对象的AutoCommit为false,即
conn.setAutoCommit(false);
),语句这样写:
String sql = "INSERT INTO flower_news (flower_news_id,news_content,news_author) VALUES (flower_news_id_s.nextval,empty_clob(),?)";
这里news_content字段为clob值。
然后再用select news_content from folwer_news where ....取出刚才插入的那条记录。
再看下面的代码:
rs = st.executeQuery(sql);
java.sql.Clob clob ;
if (rs.next()) {
clob = ((
OracleResultSet)rs).getClob(1);
oracle.sql.CLOB my_clob = (oracle.sql.CLOB)clob;
OutputStream writer = my_clob.getAsciiOutputStream();
byte[] contentStr = this.getContent().getBytes();
writer.write(contentStr);
writer.flush();
writer.close();
}
conn.commit();//到最后才提交
其中这个方法我是取到要插入的字符串
你看看吧,照这样做是没有问题的
在整个过程中你都不能提交,否则是不会成功的
原文转自:http://www.ltesting.net