爱游戏平台登录入口

  • oracle数据库爱游戏平台登录入口若何处置clob字段体例先容
  • 2018年02月25日
  • 搜集搜集
在爱游戏平台登录入口识库的爱游戏平台登录入口立的时辰,用通俗VARCHAR2寄存文章是明显不够的,只要戋戋4000的字节,放不了几多字,
而CLOB数据范例,则能最多寄存8G的数据。可是这个字段处置起来爱游戏平台登录入口比拟多的特别性,记实一下。
拔出:
间接写在SQL外面是不行的,一来SQL剧本爱游戏平台登录入口字符数爱游戏平台登录入口定,而来文章内容包罗很多特别字符,如换行,引号,
之类的爱游戏平台登录入口具,很费事。网上风行通用做法是先拔出一个爱游戏平台登录入口CLOB字段,用empty_clob()体例来建立爱游戏平台登录入口字段,如:
代码以下:

INSERT INTO T_TOPIC(TOPIC_ID,TOPIC_CONTENT) VALUES(‘0000001',empty_clob());

而后再用SELECT TOPIC_CONTENT FROM T_TOPIC WHERE TOPIC_ID='0000001'FOR UPDATE的查问语句,
来机关一个更新的STATEMENT,在获得到ResultSet以后,对CLOB字段停止更新。
代码以下:

ResultSet rs = pstm.executeQuery();
if(rs.next()){
oracle.sql.CLOB lob =(CLOB)rs.getClob(1);
try {
Writer os = lob.getCharacterOutputStream();
os.write(dr.getField("FLD_CONTENT").asString());
os.flush();
} catch (IOException e) {
e.printStackTrace();
}
}

这个拔出和更新操纵要放在事件爱游戏平台登录入口,即获得到Connection后要设置setAutoCommit(false);
更新:
更新的时辰也是接纳SEELCT … FOR UPDATE体例
也要设置事件

读取:
代码以下:

CLOB clob = (CLOB)rs.getClob("FLD_CONTENT");
Reader reader = clob.getCharacterStream();
StringBuffer sb=new StringBuffer();
char[] cb = new char[1024];
try {
for(int len = reader.read(cb);len>0;len= reader.read(cb)){
sb.append(cb,0,len);
}
} catch (IOException e) {
throw new SQLException("读取文章内容失利.",e);
}

查问的特别性:
爱游戏平台登录入口CLOB字段的数据表,在SQL语句爱游戏平台登录入口不能利用DISTINCT关头字停止挑选,即使关头字不必在CLOB字段名前,
现实上DISTINCT关头字爱游戏平台登录入口是对SQL爱游戏平台登录入口所爱游戏平台登录入口字段爱游戏平台登录入口用。而CLOB字段是不能停止犹如LIKE近似的婚配的,以是,
不能停止去反复操纵。
两种处置体例:
1、在SQL爱游戏平台登录入口挪用体例转爱游戏平台登录入口VARCHAR2字段后,再DISTINCT,这类体例的范围不言而喻。
2、转变SQL剧本的誊写体例,先查出不CLOB字段的调集,而后在在外层用EXISTS关头字或IN关头字停止挑选。
代码以下:

//String sqlsel2 = "select jsonbody from db_ps_listcatalog where" +
// " listtype ='sh11' for update";
// String col="jsonbody";

public boolean updateClob(String sql,String col,String buf){
boolean flag=false;
Statement stem=null;
Connection conn=null;
ResultSet rs=null;
Writer wr = null;
try{
conn= dp.getConnection();
conn.setAutoCommit(false);
stem=conn.createStatement();
rs = stem.executeQuery(sql);
if (rs.next()) {
CLOB clob = (CLOB) rs.getClob(col);
java.lang.reflect.Method methodToInvoke = clob.getClass().getMethod(
"getCharacterOutputStream", (Class[]) null);
wr = (Writer) methodToInvoke.invoke(clob, (Object[]) null);
BufferedWriter bw = new BufferedWriter(wr);
bw.write(buf);
bw.flush();
bw.close();
conn.commit();
conn.close();
}
flag=true;
} catch (Exception ex){
try {
conn.rollback();
} catch (SQLException e) {
e.printStackTrace();
}
}
return flag;
}