jdbc调用存储过程,遍历两个结果集(获取存储过程返回的多个结果集),珍藏版

2023-10-19 04:48

本文主要是介绍jdbc调用存储过程,遍历两个结果集(获取存储过程返回的多个结果集),珍藏版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

create table TopUsers
(
id int identity(1,1) primary key,---编号
SellerNick varchar(600),
SellerId int,


)
insert into TopUsers (SellerNick,SellerId)
values ('四海知音乐淘',123)
insert into TopUsers (SellerNick,SellerId)
values ('be旗舰店',123)
select * from TopUsers
---open_Trade a
create table open_Trade
(
id int identity(1,1) primary key,---编号
tid int,
buyer_nick varchar(200),
created varchar(200),---时间
pay_time  varchar(200),--时间
seller_nick varchar(300),
)
insert into open_Trade(tid,buyer_nick,created,pay_time,seller_nick)
values(1,123,'2015-05-05','2017-09-26','四海知音乐淘')
insert into open_Trade(tid,buyer_nick,created,pay_time,seller_nick)
values(1,123,'2016-04-08','2017-10-01','be旗舰店')
select * from open_Trade
--open_Order b
create table open_Order
(
id int identity(1,1) primary key,---编号
oid int,
tid int,
num varchar(400),
payment varchar(200),
num_iid varchar(300),


)
insert into open_Order(oid,tid,num,payment,num_iid)
values(1,1,1,1,1
insert into open_Order(oid,tid,num,payment,num_iid)
values(1,1,1,1,1)
select * from TopUsers
select * from open_Trade
select * from open_Order
op_auction_buy_informations 
@seller_id=1,
@auction=1,
@begintime=2010525, ---开始时间是
@endtime=20170829,--
@page=1
--=============================================
select a.tid,b.oid,(case when a.buyer_nick is null then '-' else a.buyer_nick end),b.num,convert(nvarchar(50),a.created,20),convert(nvarchar(50),a.pay_time,20),
convert(varchar(10),datediff(s,created,pay_time)/3600)+':'+(case when len(convert(varchar(10),(datediff(s,created,pay_time)/60)%60))=1 then '0'+convert(varchar(10),(datediff(s,created,pay_time)/60)%60) else convert(varchar(10),(datediff(s,created,pay_time)/60)%60)end)+':'+
       (case when len(convert(varchar(10),datediff(s,created,pay_time)%60))=1 then '0'+convert(varchar(10),datediff(s,created,pay_time)%60) else convert(varchar(10),datediff(s,created,pay_time)%60) end),b.payment
 from  open_Trade a(nolock),open_Order b(nolock)   where a.tid=b.tid and pay_time between '2015-05-05' and '2017-09-26' and a.seller_nick='四海知音乐淘' and b.num_iid=1 and a.pay_time<>'1970-01-01'


-- Author: <Amy>
-- Create date: <20170105>
-- Description: <宝贝购买信息表>
-- =============================================




--op_auction_buy_information @seller_id=743524358,@auction=22349808348,@begintime=20170101,@endtime=20170107,@page=2
alter PROCEDURE op_auction_buy_information
(@seller_id BIGINT  ,@auction bigint,@begintime bigint,@endtime bigint,@page int)
AS
BEGIN
SET NOCOUNT ON
declare @sller_nick nvarchar(50),@begin varchar(50),@end varchar(50),@sql nvarchar(2000),
@SQL1   nvarchar(200) 
create table #trade(Tid nvarchar(50),oid nvarchar(50),Buyer_nick nvarchar(50),Num int,Create_time nvarchar(50),Payment_time nvarchar(50),Difference_time nvarchar(50),Payment decimal(18,2))


select @begin=(@page-1)*10+1,@end=@page*10
select @sller_nick=SellerNick from TopUsers nolock where SellerId=@seller_id
 
insert into  #trade
select  distinct a.tid,b.oid,(case when a.buyer_nick is null then '-' else a.buyer_nick end),b.num,convert(nvarchar(50),a.created,20),convert(nvarchar(50),a.pay_time,20),
       convert(varchar(10),datediff(s,created,pay_time)/3600)+':'+(case when len(convert(varchar(10),(datediff(s,created,pay_time)/60)%60))=1 then '0'+convert(varchar(10),(datediff(s,created,pay_time)/60)%60) else convert(varchar(10),(datediff(s,created,pay_time)/60)%60)end)+':'+
       (case when len(convert(varchar(10),datediff(s,created,pay_time)%60))=1 then '0'+convert(varchar(10),datediff(s,created,pay_time)%60) else convert(varchar(10),datediff(s,created,pay_time)%60) end)
,b.payment from open_Trade a(nolock),open_Order b(nolock)  where a.tid=b.tid 


select @SQL1='select count(*) as 数量 from #trade '
select @sql='select distinct 父订单编号,子订单编号,买家ID,商品购买数量,下单时间,付款时间,时间差,实付金额 from (select *,ROW_NUMBER() OVER(ORDER BY 下单时间  )as RowRank from ( select Tid as 父订单编号,oid as 子订单编号,Buyer_nick as 买家ID,Num as 商品购买数量,
             Create_time as 下单时间,Payment_time as 付款时间,Difference_time as 时间差,Payment as 实付金额 from #trade ) as t1 ) as t2 where RowRank between '+ @begin +' and '+ @end +' order by 下单时间'


exec(@sql)
exec(@SQL1)
END


package com.yanshu.utils;



import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


import com.alibaba.fastjson.JSON;
import com.yanshu.service.InformationServiceImple;
/**
 * 完整版
 * @author 刘瑞光
 *
 */
public class ProcJsonUtil {
/**
* op_auction_buy_information @seller_id=743524358, @auction=22349808348, @begintime=20170101, @endtime=20170107, @page=2
* 对op_auction_buy_information进行业务处理
* @param storageName 接受存储过程的名称
* @param args 存储过程的参数
* @return 返回op_auction_buy_information的结果集
*/
public static Map<String, Object> getRui(String storageName, String[] args) throws Exception {
Connection conn = null;
CallableStatement cs = null;
ResultSet rs = null;
Map<String, Object> map = new HashMap<String, Object>();
Map<String, Object> temp = null;
List<Map<String, String>> list = null;
List<List> listlist=null;
temp=new HashMap<String, Object>();
conn = JdbcUtil.getConn();
String newStorageName = ConnSql.storageNameHandle(storageName, args.length);
cs = conn.prepareCall("{call " + newStorageName + "}");
for (int i = 0; i < args.length; i++) {
cs.setString(i + 1, args[i]);
}
cs.execute();
rs = cs.getResultSet();
if (rs != null) {
list = new ArrayList<Map<String, String>>();
List list33 = new ArrayList<>();
List list2 = new ArrayList<>();
while (rs.next()) {
ResultSetMetaData rsmd33 = rs.getMetaData();
List list99 = new ArrayList<>();
for(int i = 1; i <= rsmd33.getColumnCount(); i++)
{
String columnLabel = rsmd33.getColumnLabel(i);
Object columnValue = rs.getObject(columnLabel);
list99.add(columnLabel);
}
temp.put("columns", list99);
List listRows=new ArrayList<>();
int count=rsmd33.getColumnCount();
for (int i = 1; i <count; i++) {
listRows.add(rs.getObject(i));
}
List list3 = new ArrayList<>();
for (int i = 1; i <= rsmd33.getColumnCount(); i++) {
Object columnValue = rs.getObject(i);
list3.add(columnValue);
}
list2.add(list3);
Map<String, Object> dataMap = new HashMap<String, Object>(0);
for (int i = 1; i <= rsmd33.getColumnCount(); i++) {
dataMap.put(rsmd33.getColumnName(i), rs.getObject(i));
}
list33.add(dataMap);

}
temp.put("rows", list2);
if (cs.getMoreResults()) {
rs = cs.getResultSet();
list = new ArrayList<Map<String, String>>();
while (rs.next()) {
ResultSetMetaData rsmd11 = rs.getMetaData();
/**
* 遍历循环出表的列名--刘瑞光
*/
List list11 = new ArrayList<>();
for (int i = 0; i < rsmd11.getColumnCount(); i++) {
String columnLabel = rsmd11.getColumnLabel(i + 1);
Object columnValue = rs.getObject(columnLabel);
System.out.println(columnValue);
list11.add(columnValue);
map.put("count", columnValue);
}

}
map.put("data",temp );



}


}

return map;


}
public static void main(String[] args) throws Exception {
String[] par = new String[] { "1", "1", "20150525", "20170829", "1" };
Map<String, Object> map1 = getRui("op_auction_buy_information", par);
System.out.println(JSON.toJSON(map1));


}




}

这篇关于jdbc调用存储过程,遍历两个结果集(获取存储过程返回的多个结果集),珍藏版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应