1. 首页
  2. mybatis学习总结

MyBatis学习总结(六)——调用存储过程

一、提出需求

  查询得到男性或女性的数量, 如果传入的是0就女性否则是男性

二、准备数据库表和存储过程

 create table p_user(
     id int primary key auto_increment,
     name varchar(10),
     sex char(2)
 );

 insert into p_user(name,sex) values('A',"男");
 insert into p_user(name,sex) values('B',"女");
 insert into p_user(name,sex) values('C',"男");

 -- 创建存储过程(查询得到男性或女性的数量, 如果传入的是0就女性否则是男性)
 DELIMITER $
 CREATE PROCEDURE mybatis.ges_user_count(IN sex_id INT, OUT user_count INT)
 BEGIN
 IF sex_id=0 THEN
 SELECT COUNT(*) FROM mybatis.p_user WHERE p_user.sex='女' INTO user_count;
 ELSE
 SELECT COUNT(*) FROM mybatis.p_user WHERE p_user.sex='男' INTO user_count;
 END IF;
 END
 $

 -- 调用存储过程
 DELIMITER ;
 SET @user_count = 0;
 CALL mybatis.ges_user_count(1, @user_count);
 SELECT @user_count;

三、编辑userMapper.xml

编辑userMapper.xml文件,添加如下的配置项

 <!--
         查询得到男性或女性的数量, 如果传入的是0就女性否则是男性
      -->
     <select id="getUserCount" parameterMap="getUserCountMap" statementType="CALLABLE">
         CALL mybatis.ges_user_count(?,?)
     </select>

     <!--
         parameterMap.put("sexid", 0);
         parameterMap.put("usercount", -1);
      -->
     <parameterMap type="java.util.Map" id="getUserCountMap">
         <parameter property="sexid" mode="IN" jdbcType="INTEGER"/>
         <parameter property="usercount" mode="OUT" jdbcType="INTEGER"/>
     </parameterMap>

四、编写单元测试代码

 package me.gacl.test;

 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;

 import me.gacl.custom.model.ConditionUser;
 import me.gacl.domain.User;
 import me.gacl.util.MyBatisUtil;
 import org.apache.ibatis.session.SqlSession;
 import org.junit.Test;

 /**
  * @author gacl
  * 测试调用存储过程
  */
 public class Test6 {

     @Test
     public void testGetUserCount(){
         SqlSession sqlSession = MyBatisUtil.getSqlSession();
         /**
          * 映射sql的标识字符串,
          * me.gacl.mapping.userMapper是userMapper.xml文件中mapper标签的namespace属性的值,
          * getUserCount是select标签的id属性值,通过select标签的id属性值就可以找到要执行的SQL
          */
         String statement = "me.gacl.mapping.userMapper.getUserCount";//映射sql的标识字符串
         Map<String, Integer> parameterMap = new HashMap<String, Integer>();
         parameterMap.put("sexid", 1);
         parameterMap.put("usercount", -1);
         sqlSession.selectOne(statement, parameterMap);
         Integer result = parameterMap.get("usercount");
         System.out.println(result);
         sqlSession.close();
     }
 }

作者:孤傲苍狼

来源:https://www.cnblogs.com/xdp-gacl/p/4270352.html


JS中文网,Javascriptc中文网是中国领先的新一代开发者社区和专业的技术媒体,一个帮助开发者成长的社区,是给开发者用的 Hacker News,技术文章由为你筛选出最优质的干货,其中包括:Android、iOS、前端、后端等方面的内容。目前已经覆盖和服务了超过 300 万开发者,你每天都可以在这里找到技术世界的头条内容。

本文著作权归作者所有,如若转载,请注明出处

转载请注明:文章转载自「 Java极客技术学习 」https://www.javajike.com

标题:MyBatis学习总结(六)——调用存储过程

链接:https://www.javajike.com/article/1815.html

« MyBatis学习总结(五)——实现关联表查询
MyBatis学习总结(七)——Mybatis缓存»

相关推荐

QR code