详解java调用存储过程并封装成map
更新时间:2017年09月05日 15:02:50 作者:wjch_111
这篇文章主要介绍了详解java调用存储过程并封装成map的相关资料,希望通过本文能帮助到大家实现这样的功能,需要的朋友可以参考下
详解java调用存储过程并封装成map
本文代码中注释写的比较清楚不在单独说明,希望能帮助到大家,
实例代码:
public List<Map<String , Object>> doCallProcedure(String procedureString,String[] parameters) throws PersistentDataOperationException { if (!isReady ()) { throw new PersistentDataOperationException( "DAO is not ready."); } ResultSet rs = null; List<Map< String, Object>> list = new ArrayList<Map<String ,Object>>(); try { Connection con=session.connection(); String procedure = "{call "+procedureString+ "(?,?,?) }"; //拼装调用存储过程字符串 CallableStatement cstmt = con.prepareCall (procedure ); //调用存储过程 cstmt.setString (1,parameters [0 ]); //设置入参 cstmt.setInt (2, Integer. parseInt( parameters[ 1])) ;//设置入参 cstmt.registerOutParameter (3, oracle.jdbc.OracleTypes.CURSOR ); //设置出参 cstmt.execute (); //执行提交 rs = (ResultSet ) cstmt.getObject (3 ); //获取出参,3为参数顺序数 ResultSetMetaData rsm =rs.getMetaData (); //获得列集 Map< String, Object> map= null; int col = rsm.getColumnCount (); //获得列的个数 String colName [] = new String[ col] ;//列名集合 for (int i = 0; i < col; i++) { colName [i ] = rsm.getColumnName (i+1 ); } while( rs.next()){ //注意访问结果集是从索引位置1开始的,而不是0 map = new HashMap< String, Object> (); for (int j = 0; j < colName.length; j++) { map.put (colName [j ], rs.getString (j+1 )); } list.add (map ); } session.flush (); } catch (HibernateException e) { throw new PersistentDataOperationException( e) ; } catch (SQLException e) { e.printStackTrace (); } return list; }
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
- Java Spring动态生成Mysql存储过程详解
- MyBatis创建存储过程的实例代码_动力节点Java学院整理
- Java调用Oracle存储过程详解
- Java实现调用MySQL存储过程详解
- 详解Java的JDBC API的存储过程与SQL转义语法的使用
- java编程调用存储过程中得到新增记录id号的实现方法
- Java调用MySQL存储过程并获得返回值的方法
- java调用mysql存储过程实例分析
- Java中调用SQL Server存储过程详解
- java调用oracle分页存储过程示例
- java调用Oracle存储过程的方法实例
- Java下使用Oracle存储过程(详解)
- Java存储过程调用CallableStatement的方法
相关文章
spring-mvc/springboot使用MockMvc对controller进行测试
这篇文章主要介绍了spring-mvc/springboot使用MockMvc对controller进行测试,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-11-11Spring ApplicationListener监听器用法详解
这篇文章主要介绍了Spring ApplicationListener监听器用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2019-11-11
最新评论