java调用存储过程同时获取[返回参数]和[结果集]

来源:http://blog.csdn.net/security08/article/details/5148586

执行以下代码,报错:

String querySQL = "{?=call p_sys_manager_csReport(?,?,?,?,?)}";
cstmt = conn.prepareCall(querySQL);
cstmt.registerOutParameter(1, java.sql.Types.INTEGER);
cstmt.setInt(2, modType);
cstmt.setInt(3, dptId);
cstmt.setInt(4, eplId);
cstmt.registerOutParameter(5, java.sql.Types.VARCHAR);
cstmt.registerOutParameter(6, java.sql.Types.VARCHAR);
rs = cstmt.executeQuery();
if (rs != null) {if (rs.next()) {companyTotal = rs.getInt("companyTotal");}
}
String temp = null;
temp = cstmt.getString(5);//此行报错

报错信息为:

java.sql.SQLException: Output parameters have not yet been processed. Call getMoreResults().
    at net.sourceforge.jtds.jdbc.ParamInfo.getOutValue(ParamInfo.java:159)
    at net.sourceforge.jtds.jdbc.JtdsCallableStatement.getOutputValue(JtdsCallableStatement.java:116)
    at net.sourceforge.jtds.jdbc.JtdsCallableStatement.getString(JtdsCallableStatement.java:310)

报错信息说得很明白,就是输出结果参数未处理,必须调用getMoreResults()方法以判断是否还有结果集。

然后修改代码,问题解决:

String querySQL = "{?=call p_sys_manager_csReport(?,?,?,?,?)}";
cstmt = conn.prepareCall(querySQL);
cstmt.registerOutParameter(1, java.sql.Types.INTEGER);
cstmt.setInt(2, modType);
cstmt.setInt(3, dptId);
cstmt.setInt(4, eplId);
cstmt.registerOutParameter(5, java.sql.Types.VARCHAR);
cstmt.registerOutParameter(6, java.sql.Types.VARCHAR);
rs = cstmt.executeQuery();
if (rs != null) {if(rs.next()) {companyTotal = rs.getInt("companyTotal");}
}
String temp = null;
/**记录集获取到后,把rs记录集循环取出后或者调用cstmt.getMoreResults()方法后,sqlserver才会处理output返回值
*/
if (!cstmt.getMoreResults()) {//此行判断是否还有更多的结果集,如果没有,接下来会处理output返回参数了temp = cstmt.getString(5);//此行不再报错
}

其中改为以下代码也不报错:

if (rs != null) {while(rs.next()) {//if改为whilecompanyTotal = rs.getInt("companyTotal");}
}
String temp = null;
/** 去掉cstmt.getMoreResults(),将上面的if(rs.next()) 改为while(rs.next())也不报错
*/
//if (!cstmt.getMoreResults()) {temp = cstmt.getString(5);//此行不再报错
//}


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/497738.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在计算机网络中软件资源共享是指,在计算机网络中,软件资源共享指的是什么...

在计算机领域,共享资源(shared resource)或网络共享(network share)是指使同一个计算机网络上的其他计算机可使用的某台计算机的计算机资源的行为。换而言之,是使计算机上的一种设备或某些信息可通过另一台计算机以局域网或内部网进行远程访问&#xff0…

如何用Python和深度神经网络识别图像?

来源:王树义科学网博客概要:只需要10几行Python代码,你就能自己构建机器视觉模型,对图片做出准确辨识和分类。快来试试吧!只需要10几行Python代码,你就能自己构建机器视觉模型,对图片做出准确辨…

在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)

来源:http://www.cnblogs.com/OpenCoder/archive/2010/03/18/1689321.html 1、启用Ad Hoc Distributed Queries 在使用openrowset/opendatasource前搜先要启用Ad Hoc Distributed Queries服务,因为这个服务不安全所以SqlServer默认是关闭的 启用Ad Hoc…

单招湖南工业技术学院计算机难吗,解读湖南三一工业职业技术学院单招考试难吗...

走单招的竞争不会太激烈,因此学生们可以用不高的分数去一个比较好的专科学校。对于成绩不好的学生来说,选择单招的学生上大学的几率比较大。来我们了解一下解读湖南三一工业职业技术学院单招考试难吗什么是高职分类考试招生高职分类考试招生是普通高等教…

2017回顾:哪些领域被过度炒作,哪些领域又需要更多关注?

来源:全球创新论坛概要:不管是虚拟现实、增强现实,还是可穿戴设备,其炒作高峰似乎已经是明日黄花,已经是过去两年的事情,不知为何仍然排在炒作榜高位。不管是虚拟现实、增强现实,还是可穿戴设备…

重庆高职高专计算机排名,重庆十大大专排名(含分数线2021年参考)-重庆最好的全日制专科学校...

选择科目测一测我能上哪些大学选择科目领取你的专属报告>选择省份关闭请选择科目确定v>对于重庆考生来说,重庆专科院校的排名一直都是比较关注的话题。那么,本期圆梦志愿小编就带大家来了解一下“重庆十大大专排名及分数线”以及“重庆最好的大专全日制专科学…

无法初始化链接服务器 (null) 的 OLE DB 访问接口 Microsoft.Jet.OLEDB.4.0 的数据源对象。

SQL Server 与 Excel之间导数据时候执行SQL遇到问题 执行如下SQL语句 select * from openrowset(Microsoft.Jet.OLEDB.4.0,Excel 8.0;HDRYes;IMEX1;Databased:\sysuser.xlsx,[Sheet1$]) 提示错误: 第一步:保证Excel 文件与 SQL Server 数据库服务器在…

2018新年感谢,写在互联网类脑架构研究十年的前夜

概要:明天,是新的一年,也是我们研究互联网类脑架构,发表第一篇文章《互联网大脑进化示意图》正好10年的的日期。2018年1月1日,是新一年的第一天,也是我们研究互联网类脑架构,发表第一篇文章《互…

在SQL Server数据库之间进行数据导入导出

来源:http://kb.cnblogs.com/page/94464/ 在SQL Server数据库之间进行数据导入导出 (1).使用SELECT INTO导出数据 在SQL Server中使用最广泛的就是通过SELECT INTO语句导出数据,SELECT INTO语句同时具备两个功能: 1、根据SELECT后跟的字段…

中档微型计算机配置图,实训1-微机应用现状调研实训报告.docx

文档介绍:实训1微机应用现状调研实训报告实训内容实训要求1.微机硬件组成调研。2.市场主流微处理器信息搜集。3.主流内存信息搜集。4.微机操作系统应用调研。5.微机常用应用软件调研。6.用户对微机性能的关注程度调研。7.微机主要用途调研。通过市场的现场调研或互联…

计算机考研没奖,备战考研本科期间没有什么奖项,考研复试会有影响吗?

原标题:备战考研本科期间没有什么奖项,考研复试会有影响吗?考研复试是考研的最后阶段,因为复试采用的是差额复试,也就是进入复试人员大于拟录取人员。所以,复试还是有很大的竞争的。如何在复试中取得良好的…

HT中特殊字符φ的显示问题

HT中特殊字符φ如下才能正常显示 <text mode"1" size"1" x"1" y"9">名称:</text><text mode"1" size"1" x"6" y"9"><s:property escape"false" escapeXml&q…

2018年人工智能和机器学习路在何方?听听美国公司怎么做

来源&#xff1a;可译网翻译 | 言午二二、Amanda沈概要&#xff1a;与DevOps&#xff08;开发运营&#xff09;不同的是&#xff0c;它涉及到更多的人员和方法&#xff0c;因为新技术正在给商业管理战略带来变革。本文为美国著名数据分析网站DZone分析师Tom Smith与Exaptive的副…

oracle查看锁表进程,杀掉锁表进程

查看锁表进程SQL语句1&#xff1a; select sess.sid, sess.serial#, lo.oracle_username, lo.os_user_name, ao.object_name, lo.locked_mode from v$locked_object lo, dba_objects ao, v$session sess where ao.object_id lo.object_id and lo.session_id sess.sid; 查看锁…

2017 • AI芯片元年

本文转载自公众号&#xff1a;StarryHeavensAbove概要&#xff1a;2017年&#xff0c;AI芯片是半导体产业的亮点&#xff0c;而它受到的关注又远远超出半导体的圈子。2017年&#xff0c;AI芯片是半导体产业的亮点&#xff0c;而它受到的关注又远远超出半导体的圈子。这一年&…

计算机组成原理算术运算实验报告,计算机组成原理算术逻辑运算实验报告

计算机组成原理算术逻辑运算完整实验报告一、实验目的了解运算器的组成结构 掌握运算器的工作原理 掌握简单运算器的数据传输通路验证运算功能发生器74LS181的组合功能二、实验设备TDN&#xff0d;CM教学实验系统一套三、实验原理运算器单元电路图运算器的两个数据输入端由两个…

生产者-消费者 BlockingQueue 运用示例

简单说明&#xff1a; 1、生产者负责将字符串转换成int 数字放入BlockingQueue&#xff0c;失败就停止生产消费线程。 2、消费者从BlockingQueue获得数字&#xff0c;取平方根值&#xff0c;并累积值。如果有负数&#xff0c;失败&#xff01;停止生产消费线程。 3、模拟一个…

河北二本计算机专业排名,河北省最好的二本财经类大学有哪些

河北省最好的二本财经类大学有哪些2020-06-20 17:01:20文/刘思琪河北省是我国高考大省&#xff0c;2019年高考报名人数创近十年新高&#xff0c;报名人数达55.96万人。高考人数的增加会导致竞争更加激烈&#xff0c;那么对于分数不是很高的同学而言选择本省的一些高校是比较不错…

为什么大家都不戳破深度学习的本质?

来源&#xff1a; 36大数据概要&#xff1a;人类正在慢慢接近世界的本质——物质只是承载信息模式的载体。人脑之外的器官都只是保障这一使命的给养舰队。人类正在慢慢接近世界的本质——物质只是承载信息模式的载体。人脑之外的器官都只是保障这一使命的给养舰队。自从去年 Al…

致研究者:2018 AI 研究趋势

来源&#xff1a;网络大数据概要&#xff1a;2017 年是机器学习领域最有成效、最具创意的一年。现在已经有很多博文以及官方报道总结了学界和业界的重大突破。2017 年是机器学习领域最有成效、最具创意的一年。现在已经有很多博文以及官方报道总结了学界和业界的重大突破。本文…