十:调用存储过程返回数据
iBatic调用与JAVA调用很类似,只是JAVA把参数的注册放到了类里面,而iBatis把参数的注册放到了XML配置文件里,下面两个例子,第一个是返回普通数据,第二个是返回游标。
1:返回普通数据:
Map map = new HashMap(); map.put("username", "JACK"); sqlMapClient.queryForObject("pro_test",map); System.out.println(map); 输出结果: {o=NBA, ooo=1, oo=JACK, username=JACK}
<!-- 存储过程 --> <parameterMap class="hashmap" id="pro_map"> <parameter property="username" javaType="String" jdbcType="VARCHAR" mode="INOUT"/> <parameter property="o" javaType="String" jdbcType="VARCHAR" mode="OUT"/> <parameter property="ooo" javaType="java.lang.Integer" jdbcType="INTEGER" mode="OUT"/> <parameter property="oo" javaType="String" jdbcType="VARCHAR" mode="OUT"/> </parameterMap> <procedure id="pro_test" parameterMap="pro_map"> {call user_account_proc(?,?,?,?)} </procedure>
create or replace procedure user_account_proc ( uname in out varchar, ugroupname out varchar, uid out number, ugro out varchar ) as begin select groupname,username,userid into ugroupname,ugro,uid from user_account where username = uname; end;
2:返回一个游标:
Map map1 = new HashMap(); sqlMapClient.queryForObject("pro_cursor",map1); System.out.println(map1.get("backcursor")); 输出结果: [ {userid=1, username=JACK, userpwd=BEIJING, groupname=NBA}, {userid=2, username=TOM, userpwd=SHANGHAI, groupname=NBA}, {userid=3, username=MARY, userpwd=SHANGHAI, groupname=IBM} ]
配置文件:
<resultMap class="hashmap" id="backmap"> <result property="userid" column="USERID"/> <result property="username" column="USERNAME"/> <result property="userpwd" column="USERPWD"/> <result property="groupname" column="GROUPNAME"/> </resultMap> <parameterMap class="hashmap" id="pro_cursor_map"> <parameter property="backcursor" javaType="java.sql.ResultSet" jdbcType="ORACLECURSOR" mode="OUT" resultMap="backmap"/> </parameterMap> <procedure id="pro_cursor" parameterMap="pro_cursor_map"> {call user_account_proc1(?)} </procedure>
过程:
create or replace procedure user_account_proc1 ( my_cursor out sys_refcursor ) as begin open my_cursor for select * from user_account; end;
相关推荐
iBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。iBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。iBatis可以被看作是一个半自动化 ORM(对象关系映射)框架,它对JDBC的操作...
`ibatis`,全称为`MyBatis`,是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。在Java世界里,`ibatis`为解决繁琐的JDBC代码和手动处理结果集的问题提供了强大而灵活的解决方案。尤其在与Oracle这样...
数据库连接是软件开发中至关重要的一个环节,它允许应用程序与各种数据库进行交互,获取和存储数据。本篇文章将详细介绍七种常见的数据库连接方法,包括ODBC API、MFC ODBC、DAO、OLE DB、ADO、JDBC以及JDBC的替代...
MyBatis是支持定制化SQL、存储过程以及高级映射的持久层框架。 1. iBatis和Hibernate是两种不同的Java持久层框架,iBatis提供了更多定制化SQL和直接与数据库交互的机会,而Hibernate则提供了更为丰富的对象关系映射...
首先,Oracle部分可能涉及SQL语言和数据库管理,包括查询优化、事务处理、存储过程和触发器等。这部分内容对于任何涉及数据库操作的Java开发者来说都是必不可少的。 PL/SQL是Oracle数据库使用的编程语言,面试中...