spring jdbc 获取 clob

[b]spring jdbc 获取 clob:[/b]
String sql = "select * from user where rownum = 1";
logger.debug("sql: " + sql);

final LobHandler lobHandler = new OracleLobHandler();
List userList = jdbcTemplateAsd.query(sql,
new RowMapper() {
public Object mapRow(ResultSet rs, int i) throws SQLException {
Map results = new HashMap();
String userProfile = lobHandler.getClobAsString(rs, "USER_PROFILE");
logger.debug("userProfile:" + userProfile);
results.put("userProfile", userProfile);
return results;
}
});

String jsonString = (String) ((Map) userList.get(0)).get("userProfile");
User user = JSONObject.parseObject(jsonString, User.class);
logger.debug("user:" + user);

[b]ResultSet 获取 clob:[/b] private void clobExport() throws ClassNotFoundException, SQLException,
IOException {
CLOB clob = null;
String sql = "select * from USER where lower(CLIENT_ID) = 'test4@test.com' order by START_TIME desc";
DriverManager.registerDriver(new OracleDriver());
Connection conn = DriverManager.getConnection(url, user, pwd);
PreparedStatement stmt = conn.prepareStatement(sql);
ResultSet rs = stmt.executeQuery();
String content = "";
if (rs.next()) {
clob = (oracle.sql.CLOB) rs.getClob("USER_PROFILE");
content = ClobToString(clob);
}
stmt.close();
conn.close();
System.out.println(content);
}

public String ClobToString(CLOB clob) throws SQLException, IOException {
String reString = "";
Reader is = clob.getCharacterStream();
BufferedReader br = new BufferedReader(is);
String s = br.readLine();
StringBuffer sb = new StringBuffer();
while (s != null) {
sb.append(s);
s = br.readLine();
}
reString = sb.toString();
return reString;
}

public static void main(String[] args) throws IOException,
ClassNotFoundException, SQLException {
ClobTest clobtest = new ClobTest();
clobtest.clobExport();
}

[b]apache ToStringBuilder:[/b]public String toString(){
return ToStringBuilder.reflectionToString(this, ToStringStyle.MULTI_LINE_STYLE);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值