关键字
JDBC、注释、存储过程、人大金仓、kingbase
问题描述
应用可以通过JDBC接口执行带注释的存储过程。
问题分析
应用端缺少JDBC接口支持执行带注释存储过程的功能。
解决方案
在使用JDBC(Java Database Connectivity)操作Kes数据库时,CallableStatement的prepareCall接口支持调用语句中加入/*注释内容*/,操作的示例代码
ini
String src="/*this is note*/call p_getconfig_clob (?,?,?,?)";
CallableStatement callableStatement = connection.prepareCall(result);
callableStatement.setString(1, "foo");
callableStatement.registerOutParameter(2, Types.CLOB);
callableStatement.registerOutParameter(3, Types.VARCHAR);
callableStatement.registerOutParameter(4, Types.CLOB);
callableStatement.execute();
Clob clob = callableStatement.getClob(2);
JunitUtils.assertEquals_("asdasd", clob.getSubString(1, (int) clob.length()));
JunitUtils.assertEquals_("qweqwe", callableStatement.getString(3));
JunitUtils.assertEquals_(null, callableStatement.getClob(4));
示例展示了如何使用JDBC接口执行带注释存储过程的功能。您可以根据自己的需求进行适当的调整和扩展。
参考资料
《KingbaseES客户端编程接口指南-JDBC.pdf》