Mybatis 调用存储过程,使用Map进行输入输出参数的传递
做个记录,以备后用
java代码:
public String texuChange() throws Exception {
try {
Map<String, Object> map = new HashMap<String, Object>();
if(texu != null){
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Map<String, Object> parameterMap = new HashMap<String, Object>();
if(texu.getFlag() == 0){
parameterMap.put("v_tz_flg", 0);
}else if(texu.getFlag() == 1){
parameterMap.put("v_tz_flg", 1);
}else{
parameterMap.put("v_tz_flg", 2);
};
if(texu.getStart() != null&&texu.getEnd() != null){
parameterMap.put("v_tz_qujian_start", formatter.format(texu.getStart()));
parameterMap.put("v_tz_qujian_end", formatter.format(texu.getEnd()));
}else{
parameterMap.put("v_tz_qujian_start", null);
parameterMap.put("v_tz_qujian_end", null);
}
parameterMap.put("v_baoliu_p", texu.getBaoliup());
parameterMap.put("v_max_p", texu.getPingxianbl());
parameterMap.put("v_stop_run", texu.getStoprun());
//调用存储过程
pingbiService.texuChange(parameterMap);
map.put("p_result", parameterMap.get("p_result"));
}
responseSuccessJson(map, "", "common.list.success");
} catch(ServiceException ex) {
log.warn("input fail.", ex);
responseServiceErrorJson(getCommonInputErrorInfo(null, ex.getErrorCode()));
} catch(Exception e) {
log.error("input error.", e);
responseSystemErrorJson(getCommonErrorInfo());
}
return null;
}
public String texuChange(Map<String, Object> parameterMap) {
return pingbiDao.texuChange(parameterMap);
}
配置文件mapper
<parameterMap type="java.util.Map" id="texuChangeMap">
<parameter property="v_tz_flg" jdbcType="INTEGER" mode="IN"/>
<parameter property="v_tz_qujian_start" jdbcType="DATE" mode="IN"/>
<parameter property="v_tz_qujian_end" jdbcType="DATE" mode="IN"/>
<parameter property="v_baoliu_p" jdbcType="INTEGER" mode="IN"/>
<parameter property="v_max_p" jdbcType="INTEGER" mode="IN"/>
<parameter property="v_stop_run" jdbcType="INTEGER" mode="IN"/>
<parameter property="p_result" jdbcType="VARCHAR" mode="OUT"/>
</parameterMap>
<select id="texuChange" parameterMap="texuChangeMap" statementType="CALLABLE" resultType="String">
{call pl_texu(
?,?,?,?,?,?,?
)}
</select>
Mybatis 调用存储过程,使用Map进行输入输出参数的传递的更多相关文章
- MyBatis之四:调用存储过程含分页、输入输出参数
在前面分别讲解了通过mybatis执行简单的增删改,多表联合查询,那么自然不能缺少存储过程调用,而且还带分页功能. 注意:表结构参见上篇讲解联合查询的表. 一.查询某班级以及该班级下面所有学生的记录 ...
- 【Mybatis】MyBatis调用带有返回结果、output参数的存储过程上与ibatis的区别
用过mybatis的应该都知道它是ibatis被Google收购后重新命名的一个工程,因此也做了大量升级.本文就来介绍下两者在调用存储过程上的一点区别,ibatis有一个专门的标签<proced ...
- 使用mybatis调用存储过程(注解形式和配置文件形式)
最近在看资料中涉及到mybatis,突然想到mysql中的视图.存储过程.函数.现将在使用mybatis调用mysql的存储过程使用总结下: 使用的环境:mybatis3.4.6,mysql 5.6, ...
- MyBatis基础:MyBatis调用存储过程(6)
1. 存储过程准备 CREATE PROCEDURE sp_task ( IN userId INT ) BEGIN SELECT * FROM task WHERE user_id = userId ...
- Mybatis调用存储过程报错
Mybatis调用存储过程 贴码 123456 Error querying database. Cause: java.sql.SQLException: User does not have ac ...
- MyBatis调用存储过程,含有返回结果集、return参数和output参数
Ibatis是我们经常使用的O/R映射框架,mybats是ibatis被Google收购后重新命名的一个工程,当然也做了大量的升级.而调用存储过程也是一次额C/S架构模式下经常使用的手段,我们知道,i ...
- Mybatis学习笔记——输入参数parameterType、Mybatis调用存储过程
输入参数:parameterType(两种取值符号) 1.类型为简单类型 区别: (1) #{可以为任意值} ${vaue}--->标识符只能是value (2) ...
- mybatis 调用存储过程 返回游标 实例
存储过程示例: create or replace procedure Fsp_Plan_CheckPrj(v_grantno varchar2, v_deptcode number, v_curso ...
- mybatis调用存储过程,获取返回的游标
将调用存储过程参数放入map中,由于返回的游标中包含很多参数,所以再写一个resultmap与之对应,类型为hashmap.设置返回的jdbcType=CURSOR,resultMap设置为id对应的 ...
随机推荐
- Jmeter-BeanShell PostProcessor提取请求及响应结果并保存到本地文件
1.新建一个本地csv文件,存放请求需要使用的变量值account,password,并配置CSV Data Set Config 2.添加一个HTTP请求 3.添加正则提取器用来提取响应结果中的re ...
- Let's Encrypt 免费SSL证书
Let's Encrypt免费又好用的证书,废话不多说. 假设我的域名为:163.org 1.克隆代码 git clone https://github.com/letsencrypt/le ...
- 用netsh wlan命令行解决“Win10下WLAN不自动登陆”问题
系统崩溃了,找了一个版本Windows 10重装后,发现进入系统后不会自动连接自己家的Wifi,每次都要手动点"登录",烦不胜烦. 于是百度.Google一起上,找解决方案,然后所 ...
- 我的学习之路_第二十一章_JDBC连接池
JDBC连接池和DButils [DBCP连接池工具类] 使用读取配置文件的方式 DBCP中有一个工厂类 BasicDataSourceFactory 工厂类中有一个静态方法 返回值为: DataSo ...
- [leetcode-556-Next Greater Element III]
Given a positive 32-bit integer n, you need to find the smallest 32-bit integer which has exactly th ...
- 每篇半小时1天入门MongoDB——4.MongoDB索引介绍及数据库命令操作
准备工作 继续连接到mongo C:\Users\zouqi>mongo MongoDB shell version: 3.0.7 connecting to: test 查看数据库和集合 &g ...
- Unity应用架构设计(12)——AOP思想的实践
想象一下,当程序所有的业务逻辑都完成的时候,你可能还来不及喘口气,紧张的测试即将来临.你的Boss告诉你,虽然程序没问题,但某些方法为什么执行这么慢,性能堪忧.领会了Boss的意图之后,漫长的排查问题 ...
- HTML5性能优化[转]
在看完这两章内容之后,我意犹未尽,于是乎从网上搜索关键字“Java Web高性能”,在IBM社区找到两篇不错的文章,而让人更意外的是我发现那两篇文章的内容跟<高性能HTML5>前两章高度相 ...
- 平板点餐软件编程体会---记我的Android编程之路
前言 想开发一个平板点餐系统,研究下陈江根大侠分享的一个很高水准的实例,只是个单机版无实用意义. (如需运行源码请回复联系邮箱) 实现 Mysql 数据库+Tomcat WEb服务器,使用Servle ...
- babel如此简单
凡是看到这个标题点进来的同学,相信对babel都有了一定的了解.babel使用起来很简单,简单到都没有必要写一篇文章去介绍,直接看看官方文档就可以.所以我也在怀疑到底该不该写这篇文章.想来想去还是决定 ...