IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码

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

IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码

一、提出需求

  查询得到男性或女性的数量, 如果传入的是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/?p=15804


Warning: A non-numeric value encountered in /data/wangzhan/tech.souyunku.com.wp/wp-content/themes/dux/functions-theme.php on line 1154
赞(88) 打赏



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

IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码
IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码

评论 抢沙发

大前端WP主题 更专业 更方便

联系我们联系我们

觉得文章有用就打赏一下文章作者

微信扫一扫打赏

微信扫一扫打赏


Fatal error: Uncaught Exception: Cache directory not writable. Comet Cache needs this directory please: `/data/wangzhan/tech.souyunku.com.wp/wp-content/cache/comet-cache/cache/https/tech-souyunku-com/index.q`. Set permissions to `755` or higher; `777` might be needed in some cases. in /data/wangzhan/tech.souyunku.com.wp/wp-content/plugins/comet-cache/src/includes/traits/Ac/ObUtils.php:367 Stack trace: #0 [internal function]: WebSharks\CometCache\Classes\AdvancedCache->outputBufferCallbackHandler() #1 /data/wangzhan/tech.souyunku.com.wp/wp-includes/functions.php(5109): ob_end_flush() #2 /data/wangzhan/tech.souyunku.com.wp/wp-includes/class-wp-hook.php(303): wp_ob_end_flush_all() #3 /data/wangzhan/tech.souyunku.com.wp/wp-includes/class-wp-hook.php(327): WP_Hook->apply_filters() #4 /data/wangzhan/tech.souyunku.com.wp/wp-includes/plugin.php(470): WP_Hook->do_action() #5 /data/wangzhan/tech.souyunku.com.wp/wp-includes/load.php(1097): do_action() #6 [internal function]: shutdown_action_hook() #7 {main} thrown in /data/wangzhan/tech.souyunku.com.wp/wp-content/plugins/comet-cache/src/includes/traits/Ac/ObUtils.php on line 367