From《MyBatis从入门到精通》

    <!--
        6.2 存储过程

        6.2.1 第一个存储过程
            delimiter ;;
            create procedure 'select_user_by_id'(
                in userId bigint,
                out userName varchar(50),
                out userPassword varchar(50),
                out userEmail varchar(50),
                out userInfo TEXT,
                out headImg blob,
                out createTime datetime)
            begin
                select user_name,user_password,user_email,user_info,user_info,head_img,create_time
                into userName,userPassword,userEmail,userInfo,headImg,createTime
                from sys_user
                where id=userId;
            end
            ;;
            delimiter ;
    -->

    <!--
        存储过程不支持MyBatis的二级缓存,因此为了避免缓存配置出错,
        直接将select标签的useCache属性设置为false。headImg还特
        别设置了javaType。在MyBatis映射的Java类中,不推荐使用基本
        类型,数据库BLOB类型对应的Java类型通常都是写长bute[]字节数
        组的形式的,且byte是基本类型,所以在设置javaType时,要使用
        带下划线的方式。如果不设置,则MyBatis默认使用Byte类型
    -->
    <select id="selectUserById" statementType="CALLABLE" useCache="false">
        {call select_user_by_id(
          #{id,mode=IN},
          #{userName,mode=OUT,jdbcType=VARCHAR},
          #{userPassword,mode=OUT,jdbcType=VARCHAR},
          #{userEmail,mode=OUT,jdbcType=VARCHAR},
          #{userInfo,mode=OUT,jdbcType=VARCHAR},
          #{headImg,mode=OUT,jdbcType=BLOB,javaType=_byte[]},
          #{createTime,mode=OUT,jdbcType=TIMESTAMP}
        )}
    </select>

    <!--
        6.2.2 第二个存储过程

            delimiter ;;
            create procedure 'select_user_page'(
                in userName varchar(50),
                in _offset bigint,
                in _limit bigint,
                out total bigint)
            begin
                # 查寻数据总数
                select count(*) into total
                from sys_user
                where user_name like concat('%',userName,'%')

                #分页查询数据
                select * from sys_user
                where user_name like concat('%',userName,'%')
                limit _offset, _limit;
            end
            ;;
            delimiter ;;
    -->

    <select id="selectUserPage" statementType="CALLABLE" useCache="false"
            resultMap="userMap">
        {call select_user_page(
          #{userName,mode=IN),
          #{offset,mode=IN),
          #{limit,mode=IN),
          #{total,mode=OUT,jadbType=biging}
        )}
    </select>

    <!--
        6.2.3 第三个和第四存储过程

            # 第三个存储过程
            # 保存用户信息和角色关联信息
            delimiter ;;
            create procedure 'insert_user_and_roles'
                out userId bigint,
                in userName varchar(50),
                in userPassword varchar(50),
                in userEmail varchar(50),
                in userInfo text,
                in headImg blob,
                out createTime datetime,
                in roleIds varchar(200))
            begin
            #设置当前时间
            set crateTime=NOW();

            #插入数据
            insert into sys_user(user_name,user_password,user_email,user_info,head_img,create_time)
            values (userName,userPassword,userEmail,userInfo,headImg,createTime);

            #获取自增主键
            select last_insert_id() into userId;

            #保存用户和角色关系数据
            set roleIds = concat(',',roleIds,',');
            insert into sys_user_role(user_id,role_id);
            select userId, id from sys_role
            where instr(roleIds,concat(',',id,','))>0;
        end
        ;;
        delimiter ;
    -->
    <insert id="insertUserAndRoles" statementType="CALLABLE">
        {call insert_user_and_roles(
          #{user.id,mode=OUT,jdbcType=BIGINT},
          #{user.userName,mode=in},
          #{user.userPassword,mode=in},
          #{user.Email,mode=in},
          #{user.Info,mode=in},
          #{user.headImg,mode=in},
          #{user.createTime,mode=OUT,jdbcType=TIMESTAMP},
          #{roleIds,mode=IN}
        )}
    </insert>

    <!--
            #第四个存储过程
            delimiter ;;
                create procedure 'delete_user_by_id'(in userId bigint)
                begin
                    delete from sys_user_role where user_id=userId;
                    delete from sys_user where id=userId;
                end
                ;;
            delimiter;;
    -->
    <delete id="deleUserById" statementType="CALLABLE">
        {call delete_user_by_id(#{id,mode=in})}
    </delete>

MyBatis 存储过程的更多相关文章

  1. mysql+mybatis+存储过程+事务 + 多并发流水号获取

    数据库存储过程 drop PROCEDURE generate_serial_number; CREATE PROCEDURE generate_serial_number( ), IN param_ ...

  2. mybatis 存储过程与游标的使用

    MyBatis还能对存储过程进行完全支持,这节开始学习存储过程.在讲解之前,我们需要对存储过程有一个基本的认识,首先存储过程是数据库的一个概念,它是数据库预先编译好,放在数据库内存中的一个程序片段,所 ...

  3. MyBatis学习之简单增删改查操作、MyBatis存储过程、MyBatis分页、MyBatis一对一、MyBatis一对多

    一.用到的实体类如下: Student.java package com.company.entity; import java.io.Serializable; import java.util.D ...

  4. mybatis 存储过程调用

    接口 UserInfoMapper.java xml   UserInfoMapper.xml 如何关联 <?xml version="1.0" encoding=" ...

  5. mybatis 存储过程的写法

    (注意事项: 在使用游标的时候,不能在游标声明之前,使用crud) 存储过程示例 CREATE DEFINER=`root`@`::` PROCEDURE `earnings_proceduce`() ...

  6. mybatis调用存储过程 无参、带有输入输出参数,输出游标类型的 存储

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

  7. MyBatis学习总结(六)——调用存储过程(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013518.html 一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存 ...

  8. MyBatis调用Oracle存储过程

    MyBatis调用Oracle存储过程 1.无输入和输出参数的存储过程 2.带有输入和输出参数的存储过程 3.返回游标的存储过程 mybatis中的配置文件代码 <resultMap type= ...

  9. java, mybatis, 调用mysql存储过程

    Map<String, Object> bindinfo = new HashMap<String, Object>();            bindinfo.put(&q ...

随机推荐

  1. 用TTcpClient和TTcpServer进行文件的传输

    发送数据时有Sendln,SendBuf,SendStream.接收数据时有Receiveln,ReceiveBuf,当时我很奇怪为什么没有ReceiveStream.因为很自然的想到是对应关系的.但 ...

  2. .NET重思(三)-数组列表与数组的区别,栈集合和队列结合的区别

    数组列表和数组十分相似,区别在于数组列表的容量是可以动态变化的,而数组的容量是固定的.数组即Array类,数组列表即ArrayList类,两者十分相似.不过,Array类在System命名空间下,Ar ...

  3. URL重写 httpModules IIS7

    <system.web> <httpModules> <!--URL重写:IIS 及以下用次处配置--> <!--add name="MyHttpM ...

  4. TextBox的Enable和ReadOnly属性的限制

    在以前的ASP.NET 1.x版本中,设置为ReadOnly的TextBox控件在客户端更改了值后,在服务器端仍然可以得到修改后的值,但在ASP.NET 2.0中,这种做法已经限制.这是为了提高应用程 ...

  5. python中的while循环,格式化输出,运算符,编码

    一.while循环 1.1语法 while 条件: 代码块(循环体) else: 当上面的条件为假的的时候,才会执行. 执行顺序:先判断条件是否为真,如果是真的,执行循环体,再次判断条件,直到条件不成 ...

  6. netty中的发动机--EventLoop及其实现类NioEventLoop的源码分析

    EventLoop 在之前介绍Bootstrap的初始化以及启动过程时,我们多次接触了NioEventLoopGroup这个类,关于这个类的理解,还需要了解netty的线程模型.NioEventLoo ...

  7. 【webAssembly系列】webAssembly初探究竟

    一.前言 自从JavaScript诞生开始,到现在开始变成流行的编程语言,背后的是web发展所推动的.web应用的变得更多更复杂,但是渐渐暴露出JavaScript的问题: (1)语法太灵活导致开发大 ...

  8. chrome浏览器开发者工具F12中某网站的sources下的源码如何批量保存?

    目录 chrome浏览器 开发者工具F12中某网站的sources下的源码如何批量保存 1. 常用保存Sources源码的两种方法 1.1单个文件 1.2 单个页面 2. 问题 3.解决方案 chro ...

  9. HBase 学习之路(九)——HBase容灾与备份

    一.前言 本文主要介绍Hbase常用的三种简单的容灾备份方案,即CopyTable.Export/Import.Snapshot.分别介绍如下: 二.CopyTable 2.1 简介 CopyTabl ...

  10. C#版剑指Offer-001二维数组中的查找

    题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数 ...