专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

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',"男");  

 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();
     }
 }

来源:http://dwz.date/2UM

文章永久链接:https://tech.souyunku.com/15804

未经允许不得转载:搜云库技术团队 » MyBatis 学习总结 (六)——调用存储过程

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们