服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - JAVA教程 - mybatis调用存储过程的实例代码

mybatis调用存储过程的实例代码

2021-01-25 11:50动力节点 JAVA教程

这篇文章主要介绍了mybatis调用存储过程的实例,非常不错,具有参考借鉴价值,需要的朋友可以参考下

一、提出需求

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
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文件,添加如下的配置项

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<!--
     查询得到男性或女性的数量, 如果传入的是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>

四、编写单元测试代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
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();
  }
}

总结

以上所述是小编给大家介绍的mybatis调用存储过程的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!

原文链接:http://blog.sina.com.cn/s/blog_9c6852670102wxrz.html

延伸 · 阅读

精彩推荐
  • JAVA教程java清除html转义字符

    java清除html转义字符

    这篇文章主要介绍了一个静态文件处理的一些便捷服务,包括 java清除html转义字符,清除html代码,从style样式中读取CSS的属性,将字符串截取指定长度,涉...

    java开发网2662019-11-01
  • JAVA教程详解Struts2动态方法调用

    详解Struts2动态方法调用

    这篇文章主要介绍了详解Struts2动态方法调用,涉及调用方法的代码,具有一定参考价值,需要的朋友可以了解下。...

    春江花夜月8702021-01-11
  • JAVA教程详解Java中的BigDecimal

    详解Java中的BigDecimal

    这篇文章主要介绍了Java中的BigDecimal的使用方法,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下 ...

    zj4642020-09-17
  • JAVA教程详解Java注解教程及自定义注解

    详解Java注解教程及自定义注解

    这篇文章主要为大家详细介绍了Java注解教程及自定义注解,帮助大家更好地学习Java注解,感兴趣的小伙伴们可以参考一下 ...

    lijiao2672020-03-24
  • JAVA教程java线程并发semaphore类示例

    java线程并发semaphore类示例

    Java 5.0里新加了4个协调线程间进程的同步装置,它们分别是Semaphore, CountDownLatch, CyclicBarrier和Exchanger,本例主要介绍Semaphore,Semaphore是用来管理一个资源池的工...

    java教程网5122019-10-31
  • JAVA教程Java中对象都是分配在堆上吗?你错了!

    Java中对象都是分配在堆上吗?你错了!

    这篇文章主要介绍了Java中对象都是分配在堆上吗?你错了!文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,,需要的...

    Lovnx4822019-06-28
  • JAVA教程详解java中反射机制(含数组参数)

    详解java中反射机制(含数组参数)

    这篇文章主要介绍了详解java中反射机制(含数组参数)的相关资料,希望通过本文能帮助到大家,让大家理解掌握这部分内容,需要的朋友可以参考下...

    弃天笑7732021-01-16
  • JAVA教程谈谈对Java多态性的一点理解

    谈谈对Java多态性的一点理解

    多态就是指程序中定义的引用变量所指向的具体类型和通过该引用变量发出的方法调用在编程时并不确定,而是在程序运行期间才确定,即一个引用变量倒...

    Angel_Kitty3472020-12-21