调试了半天,其实整体用map传入传出也挺简单, 主要是调用存储过程 select标签里平时习惯不写 statementType="CALLABLE",调用没有out参数时也能正常用, 调用有out参数的过程时导致一直报java.sql.SQLException: 索引中丢失  IN 或 OUT 参数:: 6 网上的很多文章写的挺啰嗦, parameterMap要是传入的就是HashMap里面也都是基本类型根本不用写,mabatis会自动识别类型. jdbcType=INTEGER, m…
MyBatis调用Oracle存储过程 1.无输入和输出参数的存储过程 2.带有输入和输出参数的存储过程 3.返回游标的存储过程 mybatis中的配置文件代码 <resultMap type="java.util.HashMap" id="cursorMap"> </resultMap> <select id="paging" parameterType="java.util.Map" stat…
1 存储过程参数为VARCHAR 代码逻辑:controller层定义实体类对象entity,并entity.set给存储过程的输入参数赋值,把赋值后的实体类通过service层传到dao层,然后通过dao层调用存储过程 1-1 存储过程参数 IN_STR IN VARCHAR, OUT_STR OUT VARCHAR 1-2 controller层 @RequestMapping("/TESTPRO") @ResponseBody public String TESTPRO() {…
参考: http://bbs.csdn.net/topics/390866155 辅助参考: http://www.2cto.com/kf/201307/226848.html http://blog.csdn.net/grhlove123/article/details/7549290 在smm中,这样的controller编写方式是不一样的: 存储过程: create or replace procedure pro_getchart(chart_cur out sys_refcursor)…
首先根据这篇文章:http://www.cnblogs.com/coolzdp/p/7717332.html 我们知道存储过程中 SELECT * INTO 如果没有记录是不会往下执行的,直接抛出NO_DATA_FOUND异常, 这个在plsql developer中直接测试执行没问题,会报ORA-1403异常. 但是在mybatis中调用的话就不会抛出NO_DATA_FOUND异常,而是在select * into语句为空时默默的终止执行该过程. 在服务层采用事务处理的话就有问题了,服务层调用…
原文: http://tech.it168.com/oldarticle/2006-04-02/200604021512359.shtml http://www.cnblogs.com/m-cnblogs/archive/2012/02/23/2364906.html 1.创建测试存储过程:  SQL> create or replace procedure proc_test(p1 IN varchar2,p2 OUT varchar2) is  2 begin  3 SELECT p1 IN…
首先写一个存储过程: create or replace procedure p_syn_equipment_20161205 is sqlstr ); begin --清空表 sqlstr := 'truncate table staff_20161205'; execute immediate sqlstr; --插入数据 sqlstr := 'insert into staff_20161205 select * from tb_base_staff s where s.staff_nam…
package com.srie.db.pro; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; public class CallPro { public static void main(String[] args) { Connection conn = null; try { Class.forN…
<resultMap id="ticketInfosResultMap" type="Map"> <!--result要是默认用列名的话完全不必要配,省老事了 <result property="ID_" column="ID_"/> <result property="TICKET_NUMBER_" column="TICKET_NUMBER_"/&…
1.MYBATIS方法: <select id="getFlowNum" statementType="CALLABLE"> <![CDATA[ {call PRO_CFC_GETFLOWNUM( #{V_IN_RANDOM,mode=IN,jdbcType=VARCHAR},    #{V_IN_BUSCODE,mode=IN,jdbcType=VARCHAR}, #{V_IN_REFRESHVAR,mode=IN,jdbcType=VARCHA…