JDBC 支持 callable 的带注释调用解决了人大金仓数据库 KingbaseES 应用可实现调用带注释的存储过程问题

关键字

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》

相关推荐
做梦敲代码2 分钟前
达梦数据库-读写分离集群部署
数据库·达梦数据库
小蜗牛慢慢爬行43 分钟前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
hanbarger1 小时前
nosql,Redis,minio,elasticsearch
数据库·redis·nosql
微服务 spring cloud1 小时前
配置PostgreSQL用于集成测试的步骤
数据库·postgresql·集成测试
先睡1 小时前
MySQL的架构设计和设计模式
数据库·mysql·设计模式
弗罗里达老大爷1 小时前
Redis
数据库·redis·缓存
仰望大佬0072 小时前
Avalonia实例实战五:Carousel自动轮播图
数据库·microsoft·c#
学不透java不改名2 小时前
sqlalchemy连接dm8 get_columns BIGINT VARCHAR字段不显示
数据库
一只路过的猫咪2 小时前
thinkphp6使用MongoDB多个数据,聚合查询的坑
数据库·mongodb