Mybatis调用Mysql存储过程

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 在我的后台系统中,今天需要使用到存储过程。存储过程还真没写过,今天就写了个存储过程。使用在后台中。 其实这个接口功能  是涉及几张表的修改,删除,新增的。就写个一个存储过程。 存储过程: 1 CREATE PROCEDURE `sp_combine_admin_group`(IN `g...

 在我的后台系统中,今天需要使用到存储过程。存储过程还真没写过,今天就写了个存储过程。使用在后台中。

其实这个接口功能  是涉及几张表的修改,删除,新增的。就写个一个存储过程。

存储过程:

 1 CREATE PROCEDURE `sp_combine_admin_group`(IN `group_id1` int(11), IN `group_id2` int(11),IN `admin_user_id` int(11),IN `group_name` varchar(64),IN `description` varchar(1024), out `t_error` INT(11))
 2 BEGIN
 3     DECLARE new_group_id int(11);
 4     DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error=0;  
 5     SET t_error = 1;
 6       START TRANSACTION;
 7         INSERT INTO admin_group (`group_name`,`description`) values ( group_name,description);
 8         SET  new_group_id =LAST_INSERT_ID();     
 9         UPDATE group_special_power SET group_id= new_group_id  where group_id =group_id1 or group_id= group_id2;
10         UPDATE group_menu_power SET group_id= new_group_id  where group_id =group_id1 or group_id= group_id2;
11         UPDATE group_hospital_power SET group_id= new_group_id  where group_id =group_id1 or group_id= group_id2;
12         UPDATE admin_user SET is_admin=0 , admin_group_id=new_group_id  where admin_group_id =group_id1 or admin_group_id= group_id2;
13         UPDATE admin_user SET is_admin=1 where id=admin_user_id;
14         DELETE FROM  admin_group where id =group_id1 or id= group_id2; 
15       IF t_error = 0 THEN  
16              ROLLBACK;  
17       ELSE  
18              COMMIT;  
19       END IF;  
20 END;

--Mapper.xml文件调用存储过程

1 <insert id="insertAdminGroupCombine" parameterType="org.system.entity.admin.AdminGroup" useGeneratedKeys="true" keyColumn="id" statementType="CALLABLE" >
2        {call sp_combine_admin_group(
3                              #{group_id1,jdbcType=INTEGER,mode=IN},
4                              #{group_id2,jdbcType=INTEGER,mode=IN},
5                              #{admin_user_id,jdbcType=INTEGER,mode=IN},
6                              #{group_name,jdbcType=VARCHAR,mode=IN},
7                              #{description,jdbcType=VARCHAR,mode=IN},
8                              #{t_error,jdbcType=INTEGER,mode=OUT})}
9     </insert>

 

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
17天前
|
存储 SQL 关系型数据库
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)
|
27天前
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
20 1
|
27天前
Mybatis+mysql动态分页查询数据案例——房屋信息的实现类(HouseDaoMybatisImpl)
Mybatis+mysql动态分页查询数据案例——房屋信息的实现类(HouseDaoMybatisImpl)
21 2
|
27天前
Mybatis+mysql动态分页查询数据案例——工具类(MybatisUtil.java)
Mybatis+mysql动态分页查询数据案例——工具类(MybatisUtil.java)
15 1
|
11天前
|
存储 SQL 关系型数据库
mysql存储过程示例
mysql存储过程示例
11 0
|
27天前
|
Java 数据库连接 mybatis
Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
14 1
|
27天前
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
14 1
|
1月前
|
存储 关系型数据库 MySQL
Mysql基础第二十六天,使用存储过程
Mysql基础第二十六天,使用存储过程
28 0
Mysql基础第二十六天,使用存储过程
|
1月前
|
存储 SQL 关系型数据库
【MySQL 数据库】9、存储过程
【MySQL 数据库】9、存储过程
204 0
|
3月前
|
存储 关系型数据库 MySQL
MySQL-调用存储过程
MySQL-调用存储过程
101 2