Mybatis调用Mysql存储过程-阿里云开发者社区

开发者社区> 陈嘻嘻哈哈> 正文

Mybatis调用Mysql存储过程

简介: 在我的后台系统中,今天需要使用到存储过程。存储过程还真没写过,今天就写了个存储过程。使用在后台中。 其实这个接口功能  是涉及几张表的修改,删除,新增的。就写个一个存储过程。 存储过程: 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>

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
C/C++封装库ocicpplib调用Oracle存储过程的方法
工作这么多年,一直使用Mysql, Oracle数据库没有接触过, 这次要使用C/C++语言来调用Oracle的存储过程, 懒得自己去看OCI的API了, 直接上网找别人封装的库, 最后发现了这个ocicpplib, 下载了看了一下, 还不错, 使用起来比较简单。
1069 0
OTL调用Oracle存储过程
OTL很早前用过,今天写东西要调存储过程,程序写完了,调试死活通不过,折腾了一早晨。 最后才发现错误,这里总结一下: 1、代码写的不规范。 有个参数后边少写了个“,”以至于总是抱错。而单独写的测试例子就没问题,后来一步一步跟踪了后才发现。
1367 0
Node.js调用mysql的存储过程
例子仅在windows下测试通过,没有放在linux下测试。如有问题,可以电邮给我~ 1、安装node.js、mysql,此处略(自行搜索吧)…; 2、创建一个名为test的数据库,然后建一张名为user_info的表(仅供测试)… 这里假定mysql使用的用户名为root,密码为123456 相应...
902 0
JDBC调用存储过程,以及存储过程 事务的使用.....
在JDBC中调用存储过程 首先就要在数据库中存在 要调用的过程  ,存储过程是一组SQL语句的集合,我们吧实现某一功能的 SQL语句集合在一起来使用,方便了用户,不光是这样,存储过程可以预编译,也就是说只要调用了一次存储过程,那么下次在调用存储过程的时候 就不需要进行再次编译了  。
821 0
mysql 创建事件及调用
mysql 创建事件及调用 创建事件 CREATE EVENT 的语法如下: CREATE EVENT [IF NOT EXISTS] ---------------------------------------------*标注1 event_name -----------------.
1193 0
Mybatis调用Mysql存储过程
在我的后台系统中,今天需要使用到存储过程。存储过程还真没写过,今天就写了个存储过程。使用在后台中。 其实这个接口功能  是涉及几张表的修改,删除,新增的。就写个一个存储过程。 存储过程: 1 CREATE PROCEDURE `sp_combine_admin_group`(IN `g...
753 0
C# 调用存储过程操作 OUTPUT参数和Return返回值
本文转载:http://www.cnblogs.com/libingql/archive/2010/05/02/1726104.html   存储过程是存放在数据库服务器上的预先编译好的sql语句。使用存储过程,可以直接在数据库中存储并运行功能强大的任务。
863 0
+关注
陈嘻嘻哈哈
我是一个小小的程序媛!
241
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载