oracle pl sql clob,PL/SQL 中获取CLOB字段的具体内容

经常会遇到表中的字段定义的数据类型为clob,如下图,request_param字段是clob类型存储的是一个json格式的报文。

e643ebeb29dd

image.png

oracle中的clob类型字段不能直接显示出来,那么想要获取上述clob里的具体内容,该怎么处理呢?

借助Oracle系统dbms_lob中substr方法

格式为:select dbms_lob.substr(clobField) from table

e643ebeb29dd

image.png

但是使用上述方法会存在一个问题:字段里存储的报文过长时,会显示不全。

所以就需要其他方多处理,这里使用java连接oracle,写了一个方式,只需要传递一个参数,即select clobField from table的结果即可。

pom.xml文件中加入连接数据库所需包:

com.oracle

ojdbc6

11.2.0.3.0

创建数据连接类 DbcpConnection

package com.cccis.jmeter.util.help;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.SQLException;

/**

* Created by Sundy on 2018/6/21.

*/

public class DbcpConnection{

//数据库驱动名字

private static String jdbcName = "oracle.jdbc.driver.OracleDriver";

//数据库协议地址

private static String dbUrl = "jdbc:oracle:thin:@192.168.200.25:1521:orcl";

//数据库用户名

private static String dbUser = "apd_v362_test";

//数据库密码

private static String dbPassword = "apd_v362_test";

public DbcpConnection(){}

public static Connection getConnection(){

Connection conn =null;

try {

Class.forName(jdbcName);

conn = DriverManager.getConnection(dbUrl, dbUser, dbPassword);

} catch (SQLException e) {

e.printStackTrace();

}catch (ClassNotFoundException e) {

e.printStackTrace();

}

return conn;

}

}

新增DBUtil工具类:

package com.cccis.jmeter.util.help;

import java.io.BufferedReader;

import java.io.IOException;

import java.io.Reader;

import java.sql.*;

/**

* Created by Sundy on 2018/6/21.

*/

public class DBUtil {

public static String ClobConvert(String sql) {

Connection conn = DbcpConnection.getConnection();

PreparedStatement pstmt = null;

String result=null;

try {

pstmt = conn.prepareStatement(sql);

ResultSet rs = pstmt.executeQuery();

while (rs.next()) {

Clob clob = (Clob) rs.getObject(1);

result = ClobToString(clob);

}

} catch (SQLException e) {

e.printStackTrace();

}

return result;

}

public static String ClobToString(Clob clob) {

String reString = "";

try {

Reader is = null;// 得到流

is = clob.getCharacterStream();

BufferedReader br = new BufferedReader(is);

String s = br.readLine();

StringBuffer sb = new StringBuffer();

while (s != null) {// 执行循环将字符串全部取出付值给StringBuffer由StringBuffer转成STRING

sb.append(s);

s = br.readLine();

}

reString = sb.toString();

} catch (IOException e) {

e.printStackTrace();

}catch (SQLException e) {

e.printStackTrace();

}

return reString;

}

public static void main(String[] args) {

String ss = null;

ss = ClobConvert("select request_param from t_interface_log l where l.business_no='CN062114485333' and l.interface_code='ClaimInfoSync'");

System.out.println(ss);

}

}

上述测试结果为:

e643ebeb29dd

image.png

ok了,成功将数据库中clob字段的具体内容取出。

后续可以在jmeter接口测试时,将上述工程打包后,在BeanShell内直接调用。例如:

e643ebeb29dd

image.png

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值