MyBatis存储过程的使用问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis存储过程的使用问题相关的知识,希望对你有一定的参考价值。

Mybatis+Spring我在使用myBatis的存储过程时的map参数是使用iBATIS的格式: 应为我在mybatis3的用户指南文档上没看到存储过程的使用说明,就按照iBATIS的格式来写<mapper namespace="pageView">    <parameterMap type="Map" id="pageParameter">        <parameter property="i_tableName" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>        <parameter property="i_searchFields" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>        <parameter property="i_pageIndex" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>.....在使用的时候 是这样的<select id="getUserPageList" parameterType= "pageView.pageParameter" resultType="User">...启动服务是报错,诚请高手帮忙解决,错误信息:org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userDao' defined in file [E:\StyleWorkspace\.metadata\.plugins\com.genuitec.eclipse.easie.tomcat.myeclipse\tomcat\webapps\SSMybatis\WEB-INF\classes\applicationContext-annex.xml]: Cannot resolve reference to bean 'sqlSessionFactory' while setting bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in file [E:\StyleWorkspace\.metadata\.plugins\com.genuitec.eclipse.easie.tomcat.myeclipse\tomcat\webapps\SSMybatis\WEB-INF\classes\applicationContext-core.xml]: Invocation of init method failed; nested exception is org.apache.ibatis.builder.BuilderException: Error parsing SQL Mapper Configuration. Cause: java.lang.RuntimeException: Error parsing Mapper XML. Cause: org.apache.ibatis.builder.BuilderException: Error resolving class . Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'pageView.pageParameter'. Cause: java.lang.ClassNotFoundException: Cannot find class: pageView.pageParameter有mybatis存储过程使用的帮忙讲一下,能有示例就更好

参考技术A 我在项目中也用到的存储过程,而且完全没问题!!下面是我的使用方式:
Mapper.xml 文件:
<!-- 存储过程
CREATE PROCEDURE proc_transno
(
p_trnxcode char(2),
p_reqtype char(1),
p_ischangemoney char(1),
out p_transno char(20)
)
...
-->
<selectid="callTransNo"statementType="CALLABLE">
call
proc_transno(#
p_trnxcode,
mode=IN,
javaType=java.lang.String,
jdbcType=VARCHAR
,
#
p_reqtype,
mode=IN,
javaType=java.lang.String,
jdbcType=VARCHAR
,
#
p_ischangemoney,
mode=IN,
javaType=java.lang.String,
jdbcType=VARCHAR
,
#
p_transno,
mode=OUT,
javaType=java.lang.String,
jdbcType=VARCHAR,
resultType=java.lang.String
)

</select>

DAO 里面的调用:
@Override
public String getTransNo(String trnxCode, boolean isReqOrRes, boolean isChangeMoney)
String chrisReqOrRes = (isReqOrRes ? "1" : "0");
String chrisChangeMoney = (isChangeMoney ? "1" : "0");
Map<String, Object> paramter = new HashMap<String, Object>(3);
paramter.put("p_trnxcode", trnxCode);
paramter.put("p_reqtype", chrisReqOrRes);
paramter.put("p_ischangemoney", chrisChangeMoney);
this.getSqlSession().selectOne("com.haohui.hxtrans.domin.TransNo.callTransNo", paramter);
final String transNo = paramter.get("p_transno").toString();
return transNo;

使用mybatis执行oracle存储过程

存储过程在小公司用的不多,但是如果业务比较复杂或者性能要求比较苛刻的时候存储过程就派上用场了,ibatis的前期的一些版本貌似不支持存储过程因此我选择了mybatis来做实验。

1.无输入和输出参数的存储过程,我写了一个比较简单的,需要注意的是Oracle无参存储过程不能写括号

CREATE OR REPLACE Procedure cascadeoperation
As
Begin
 Delete From teacher Where id=1;
 Update studentdetail Set address=‘宁波市海曙区‘ Where studentid=10;
End;


这里执行了2个操作,可能用过mybatis的人会迷惑执行的时候到底使用update标签呢还是delete标签,其实都行,我也试过select标签也是OK的,下面是部分的配置文件

<delete id="cascadeOperation" statementType="CALLABLE" >
	   {call cascadeoperation}
	</delete>


2.带有输入和输出参数的存储过程,我这里加入了if else的几个判断

CREATE OR REPLACE Procedure queryTeacher(fid In Integer,Type In Varchar,Name Out Varchar)
As
Begin
If Type=‘1‘ then
Select Name Into Name From student Where id=fid;
Else if Type=‘2‘ Then
Select Name Into Name From teacher Where id=fid;
Else 
 Name:=‘错误‘;
End If;
End If;
End;


下面顺便把我在命令行窗口执行的存储过程语句贴出来

Declare
Name  Varchar2(50);
Begin
queryteacher(3,‘2‘,Name);
DBMS_OUTPUT.put_line(Name);
End;
/


执行过类似语句的时候可能看不到任何的输出,不要着急只需在命令行使用set serveroutput on;即可来看下我的执行结果

技术分享 

看到结果了吧,下面使用mybatis来执行这个存储过程,下面是映射文件的写法

<select id="queryTeacher" statementType="CALLABLE" parameterType="java.util.Map">
	   {call queryTeacher(#{fid,mode=IN,jdbcType=INTEGER},#{type,mode=IN,jdbcType=VARCHAR},#{name,mode=OUT,jdbcType=VARCHAR})}
	</select>


那怎么取得返回的内容呢,其实只要存储过程执行后map里就有值了,java代码大致如下

Map<String,Object> mm=new HashMap<String,Object>();
 mm.put("fid", 3);
 mm.put("type", 2);
 m.queryTeacher(mm);
 System.out.println(mm.get("name"));

 

下面是控制台输出的结果

技术分享 

3.还有一种存储过程,它可以返回一个游标就类似一个集合这种

CREATE OR REPLACE Procedure getTeacher(cur_arg out Sys_Refcursor)
As
begin
    open cur_arg for Select * From teacher;
End;


这种情况,在mybatis里就稍微有些不同了,此时jdbcType就是CURSOR,javaType则是ResultSet了,这里还可以把结果转成resultMap了,如下所示

<resultMap id="resultMap3" type="org.lxh.module.usefunction.info.Teacher">
	<result property="address" column="address"/>
	<result property="name" column="name"/>
	<result property="id" column="id"/>
   </resultMap>

 

<select id="getAllTeacherInfo" statementType="CALLABLE" parameterType="java.util.Map" >
	   {call GETTEACHER(#{result,jdbcType=CURSOR,mode=OUT,javaType=ResultSet, resultMap=resultMap3})}
	</select>

 

这里的话Java代码就稍微复杂一些

Map<String, Object> map = new HashMap<String, Object>();
		m.getAllTeacher(map);
		Set<Map.Entry<String, Object>> set = map.entrySet();
		for (Iterator<Map.Entry<String, Object>> it = set.iterator(); it
				.hasNext();) {
			Map.Entry<String, Object> entry = (Map.Entry<String, Object>) it
					.next();
			// System.out.println(entry.getKey() + "--->" +
			// (Teacher)entry.getValue());
			List<Teacher> t = (List<Teacher>) entry.getValue();
			Iterator<Teacher> itera = t.iterator();
			while (itera.hasNext()) {
				Teacher tt = itera.next();
				System.out.println(tt.getName() + "," + tt.getAddress());
			}

		}


下面是执行结果

技术分享 

到这里存储过程已经差不多了,研究了好久才弄出来,其他的用jdbc执行存储过程我随后会把文章添上来。 技术分享

 

转载:http://www.360doc.com/content/14/0728/16/7662927_397682668.shtml








以上是关于MyBatis存储过程的使用问题的主要内容,如果未能解决你的问题,请参考以下文章

使用mybatis执行oracle存储过程

mybatis 调用存储过程

使用 Mybatis 将布尔参数传递给存储过程

mybatis使用存储过程

MyBatis 使用删除注解调用存储过程

mybatis 存储过程