JDBC调用MogDB存储过程返回ref_cursor的方法和注意事项

2024-05-11 23:44

本文主要是介绍JDBC调用MogDB存储过程返回ref_cursor的方法和注意事项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MogDB在处理存储过程的时候,有时候需要返回结果集,类型为ref_cursor,但有时候可能会报错。而大部分应用程序都是使用Java JDBC.

根据我们这几年的数据库国产化改造经验,给大家分享一下JDBC调用 MogDB存储过程返回ref_cursor的方法和注意事项。

创建测试用存储过程

该存储过程有两个OUT参数,其中一个返回结果集(sys_refcursor),返回的行数根据第一个参数的长度而定,接下来看看代码。

create or replace procedure test_proc_return_cursor(a varchar,mycur OUT sys_refcursor, total_rows OUT int)
as
begin
total_rows :=length(a);
open mycur for 'select substr(x,1,id),id from (select x,generate_series(1,length(x)) as id from (select :a as x))' using a;
end;

创建Java测试代码

import java.sql.*;

public class TestReturnCursor {
    public static void main(String[] args) throws SQLException, ClassNotFoundException {
        TestReturnCursor test = new TestReturnCursor();
        test.runTest();
    }

   private void runTest() throws SQLException, ClassNotFoundException {
       Class.forName("org.opengauss.Driver");
# 此处替换成准确的ip/port/user/password
       Connection conn = DriverManager.getConnection("jdbc:opengauss://192.168.56.110:26000/postgres?loggerLevel=off","testproc","Test@123");
       conn.setAutoCommit(false);
       CallableStatement cs = (conn.prepareCall ("{call " + "test_proc_return_cursor(?,?,?)}")) ;
        cs.setString(1,"Test return ref_cursor");
        cs.registerOutParameter(2,Types.REF_CURSOR);
        cs.registerOutParameter(3,Types.INTEGER);

        cs.execute();

        ResultSet rs=(ResultSet)(cs.getObject(2));
        System.out.println("Total rows:"+cs.getInt(3));

        while(rs.next()){
            System.out.println(rs.getInt(2)+" "+rs.getString(1));
        }
        rs.close();
        cs.close();
        conn.close();
    }
}

准备好测试用例之后,接下来我们来编译一下。

编译java程序

javac *.java 
java -cp opengaussjdbc.jar:. TestReturnCursor 

如下是编译执行的结果输出:

alt

Connection对象不设置autocommit=false的情况分析。

上述测试代码中,里面有个关键点,Connection对象的autocommit必须设置为false,否则会有如下报错: ERROR: cursor “<unnamed portal 1>” does not exist

alt

原因是在产生ref_cursor的时候,如果没有设置autocommit为false, 则内部自动提交,建立的ref_cursor对象在事务外不可见。

总结

1、registerOutParameter里,type可以设成Types.REF_CURSOR,也可以设成Types.OTHER

2、获取结果集时,使用getObject()方法,并将其转换成ResultSet对象。注意CallableStatement.getResultSet()不是这个用途。

3、最关键的一点,Connection对象需要设置autocommit=false.


更多详细信息请参考www.mogdb.io

本文由 mdnice 多平台发布

这篇关于JDBC调用MogDB存储过程返回ref_cursor的方法和注意事项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/980999

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll