jdbc取mysql存储过程多个结果集

1 篇文章 0 订阅

 先来返回结果格式:

[
    [
        {"name":"分管公司1","id":"1000"},
        {"name":"分管公司2","id":"1001"},
        {"name":"分管公司3","id":"1014"},
        {"name":"分管公司4","id":"1015"},
        {"name":"分管公司5","id":"1016"},
        {"name":"分管公司6","id":"1017"}
    ],
    [
        {"哈哈":""}
    ],
    [
        {"呵呵":2}
    ]
]

java代码: 

调用存储过程个方法针对框架进行封装过,大家可以忽略也可替换,cs.execute();后辨识解析的返回值的代码

public List callShellProcedureList(final String param){
		System.out.println(1);
		List list = jdbcTemplate.execute(new CallableStatementCreator() {
			public CallableStatement createCallableStatement(Connection con) throws SQLException {
				String storedProc = "{call USP_PRG_CallShellProcedure(?)}";// 调用存储过程名
				CallableStatement cs = con.prepareCall(storedProc);
				cs.setString(1, param);// 设置输入参数的值
				return cs;
			}
		}, new CallableStatementCallback<List>() {
			public List doInCallableStatement(CallableStatement cs) throws SQLException, DataAccessException {
				cs.execute();
				List list1 =new ArrayList();
				ResultSet resultSet = cs.getResultSet();//获取第一个resultSet
				//result 封装结果集
				List<Map<String, Object>> result = new ArrayList<Map<String, Object>>();
				if(null != resultSet)
				{
					ResultSetMetaData data = resultSet.getMetaData();
					if (null != data) {
						//每循环一次遍历出来1条记录,记录对应的所有列值存放在map中(columnName:columnValue)
						while (resultSet.next()) {
							Map<String, Object> map = new HashMap<String, Object>();
							for (int i = 0; i < data.getColumnCount(); i++)
								//以键值对存放数据
								//直接存放字段名称
								//map.put(data.getColumnName(i + 1), rs.getObject(i + 1));
								//直接存放字段的别名
								map.put(data.getColumnLabel(i + 1), resultSet.getObject(i + 1));
							result.add(map);
						}
						list1.add(result);
					}
					while(cs.getMoreResults())//判断是否还有结果集如果有就进入循环去取值
					{
						List<Map<String, Object>> results = new ArrayList<Map<String, Object>>();
						resultSet = cs.getResultSet();//这里去到的是当前getMoreResults()里面的getResultset
						ResultSetMetaData datas = resultSet.getMetaData();
						if (null != datas) {
							//每循环一次遍历出来1条记录,记录对应的所有列值存放在map中(columnName:columnValue)
							while (resultSet.next()) {
								Map<String, Object> map = new HashMap<String, Object>();
								for (int i = 0; i < datas.getColumnCount(); i++)
									//以键值对存放数据
									//直接存放字段名称
									//map.put(data.getColumnName(i + 1), rs.getObject(i + 1));
									//直接存放字段的别名
									map.put(datas.getColumnLabel(i + 1), resultSet.getObject(i + 1));
								results.add(map);
							}
							list1.add(results);
						}
					}
				}
				return list1;
			}
		});
		return list;
	}

 

传入要调用的存储过程接口

这个方法会将多返回集以数组的方式返回出来

返回示例:

[
    [
        {"name":"分管公司1","id":"1000"},
        {"name":"分管公司2","id":"1001"},
        {"name":"分管公司3","id":"1014"},
        {"name":"分管公司4","id":"1015"},
        {"name":"分管公司5","id":"1016"},
        {"name":"分管公司6","id":"1017"}
    ],
    [
        {"哈哈":""}
    ],
    [
        {"呵呵":2}
    ]
]

存储过程代码:

begin

select s1.name,s1.id from sys_office as s1,(select LENGTH(parent_ids)  - LENGTH(REPLACE( `parent_ids`,',','' )) as countdou,parent_ids from sys_office
where parent_ids LIKE '%0,318d76c07c2540259b16c63df273d7b3,%' and del_flag =0 
GROUP BY parent_ids
order by countdou DESC 
LIMIT 0,1) as s2 
where s1.parent_ids = s2.parent_ids and s1.del_flag =0 ;
select null as `哈哈`;
select 2 as `呵呵`;

end

如果遇到问题的话可以加我qq讨论一下 1311353736

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 对于Java调用MySQL存储过程,可以使用JDBC驱动提供的CallableStatement类来实现。以下是一个示例代码,展示如何调用MySQL存储过程同时获输出参数和结果: ```java // 假设存储过程名为test_proc,有一个输入参数和一个输出参数 String sql = "{CALL test_proc(?, ?)}"; CallableStatement cs = conn.prepareCall(sql); // 设置输入参数 cs.setString(1, "input_value"); // 注册输出参数,需要指定参数类型和输出参数位置 cs.registerOutParameter(2, java.sql.Types.VARCHAR); // 执行存储过程 ResultSet rs = cs.executeQuery(); // 处理结果 while (rs.next()) { // 处理每一行结果 } // 获输出参数值 String outputValue = cs.getString(2); // 关闭资源 rs.close(); cs.close(); ``` 需要注意的是,输出参数的位置从1开始计数,而不是从0开始计数。在注册输出参数时,需要指定输出参数的类型,如java.sql.Types.VARCHAR表示字符串类型。 另外,如果存储过程返回多个结果,可以使用cs.getMoreResults()方法获下一个结果。在处理完所有结果后,需要显式地调用cs.getUpdateCount()方法获存储过程执行后影响的行数。 ### 回答2: Java调用MySQL存储过程的输出参数和结果可以通过Java JDBC驱动程序来实现。 首先,需要使用JDBC连接数据库,获数据库连接对象Connection。然后,通过Connection创建CallableStatement对象,用于调用存储过程。在调用存储过程之前,需要设置存储过程的参数和输出模式。 对于存储过程的输出参数,可以使用registerOutParameter方法设置参数的输出模式。例如,如果存储过程的输出参数是一个整数类型,可以使用以下代码设置输出参数的模式: ```java CallableStatement cstmt = conn.prepareCall("{call stored_procedure_name(?)}"); cstmt.registerOutParameter(1, Types.INTEGER); ``` 在调用存储过程之后,可以使用get方法获输出参数的值。例如,如果存储过程的输出参数是一个整数类型,可以使用以下代码获输出参数的值: ```java int outputParam = cstmt.getInt(1); ``` 对于存储过程的结果,可以使用executeQuery方法执行存储过程返回ResultSet对象。例如,如果存储过程返回一个查询结果,可以使用以下代码获结果: ```java ResultSet rs = cstmt.executeQuery(); while (rs.next()) { // 处理结果 } ``` 最后,记得在使用完CallableStatement和ResultSet之后,要关闭它们,释放资源。 总结起来,Java调用MySQL存储过程的输出参数和结果的步骤如下: 1. 创建数据库连接对象Connection。 2. 使用Connection创建CallableStatement对象,并设置存储过程的输出参数。 3. 调用存储过程,并获输出参数的值。 4. 使用executeQuery方法执行存储过程,获结果,并处理结果。 5. 关闭CallableStatement和ResultSet,释放资源。 需要注意的是,以上代码只是一个基本的示例,实际使用时还需要根据具体的存储过程和参数进行调整。 ### 回答3: 在Java中调用MySQL存储过程的输出参数和结果,可以通过JDBC来实现。 首先,需要建立数据库连接,使用java.sql包中的DriverManager类和Connection接口。通过调用DriverManager类的getConnection方法来获数据库连接对象Connection,传入数据库的连接信息,如URL、用户名、密码。 接下来,可以通过PreparedStatement接口来执行存储过程。使用Connection的prepareCall方法来创建一个CallableStatement对象,并传入调用存储过程的SQL语句。 对于输出参数,可以使用registerOutParameter方法将存储过程的输出参数注册到CallableStatement对象中,指定参数的索引和类型。 对于结果,可以使用execute方法来执行存储过程,然后使用getResultSet方法获得返回的结果。 最后,可以使用getXXX方法来获输出参数的值,如getInt、getString等方法。 下面是一个示例代码片段,演示了如何调用MySQL存储过程的输出参数和结果: ```java import java.sql.*; public class MySQLStoredProcedure { public static void main(String[] args) { try { // 建立数据库连接 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "username", "password"); // 创建CallableStatement对象 CallableStatement stmt = conn.prepareCall("{call get_user_info(?, ?)}"); // 注册输出参数 stmt.registerOutParameter(2, Types.VARCHAR); // 执行存储过程 stmt.execute(); // 获输出参数的值 String outputParam = stmt.getString(2); System.out.println("Output parameter: " + outputParam); // 获结果 ResultSet rs = stmt.getResultSet(); while (rs.next()) { // 处理结果数据 int id = rs.getInt("id"); String name = rs.getString("name"); System.out.println("ID: " + id + ", Name: " + name); } // 关闭连接和结果 rs.close(); stmt.close(); conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 总结起来,通过JDBC可以在Java中调用MySQL存储过程的输出参数和结果。需要使用CallableStatement对象来执行存储过程,并通过registerOutParameter方法注册输出参数,使用execute方法执行存储过程并获结果。最后,通过getXXX方法获输出参数的值,通过遍历结果其中的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值