MyBatis 调用Oracle存储过程,使用Map传递参数
程序员文章站
2022-06-03 23:53:05
...
1.存储过程(没有return关键字返回结果集,可以通过out输出结果集)
CREATE OR REPLACE Procedure aaa(num In Varchar,Type In Varchar,Name Out Varchar)
As
Begin
If Type='1' then
Select channels Into Name From bdp_bi.xx_test Where nums=num;
Else if Type='2' Then
Select types Into Name From bdp_bi.xx_test Where nums=num;
Else
Name:='错误';
End If;
End If;
End;
2.MyBatis的xml文件
<parameterMap type="java.util.Map" id="paraMap">
<parameter property="num" jdbcType="VARCHAR" mode="IN" javaType="String"/>
<parameter property="type" jdbcType="VARCHAR" mode="IN" javaType="String"/>
<parameter property="name" jdbcType="VARCHAR" mode="OUT" javaType="String"/>
</parameterMap>
<select id="callPro" statementType="CALLABLE" parameterMap="paraMap">
{ call bdp_bi.aaa(?,?,?) }
</select>
3.DAO层(注:返回值为空,从out中取结果集)
void callPro(Map<String, Object> map);
4.service层
public Map<String, Object> callPro(String num,String type){
Map<String, Object> map = new HashMap<String, Object>();
map.put("type", type);
map.put("num", num);
goldProductDao.callPro(map);
System.out.println(map.get("name"));
return map;
}
上一篇: mysql存储过程总结
下一篇: ReJava-学前
推荐阅读
-
oracle 存储过程详细介绍(创建,删除存储过程,参数传递等)
-
编程开发之--Oracle数据库--存储过程在out参数中使用光标(3)
-
oracle 存储过程详细介绍(创建,删除存储过程,参数传递等)
-
Oracle数据库基本操作 (五) —— 使用java调用存储过程
-
编程开发之--Oracle数据库--存储过程在out参数中使用光标(3)
-
用PDO调用oracle存储过程,返回参数为游标,怎么提取数据
-
MyBatis 调用Oracle存储过程,使用Map传递参数
-
Mybatis调用Oracle返回结果集存储过程
-
Python如何使用cx_Oracle调用Oracle存储过程的示例
-
Java调用Oracle存储过程传入数组参数的方法