mysql 存储过程 事务; mysql的事务中包含一个存储过程
在asp.net结合mysql的开发中,我平时用到的事务处理是 使用 TransactionOptions 来进行处理
TransactionOptions transactionOption = new TransactionOptions
{
IsolationLevel = IsolationLevel.ReadCommitted, //设置事务隔离级别
Timeout = new TimeSpan(0, 5, 10) // 设置事务超时时间为5分10秒
};
using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required, transactionOption))
{
try
{
string temp = jkController.Changepoint(mobile, actionType, actionId, point); if (temp == "already_login")
{
throw new MessageJxtException(Message.一天只能获取一次登陆积分);
}
else if (temp == "already_vote")
{
throw new MessageJxtException(Message.一个投票只能获取一次投票积分);
}
else
{
outPoint = Convert.ToInt32(temp);
}
scope.Complete(); //提交事务
}
catch (Exception ex)
{
throw new MessageJxtException(Message.操作失败本次操作没有执行);
}
}
这样写了之后,mysql的存储过程里面不需要做特殊处理,你写2个sql语句,任意一个报错,都会在asp.net里面被回滚的(准确的说,是如果没有报错的话,就会和自行到scope.Complete()来执行提交,否则,就不会提交,也就达到了事务)
但是现在有另外一个客户端是php来编写的,如果让php写来写这样的事务,感觉太麻烦,倒不如我直接去mysql里面写事务好了
好,今天就来介绍mysql内置的事务处理
DELIMITER $$ USE `test`$$ DROP PROCEDURE IF EXISTS `test_shiwu`$$ CREATE DEFINER=`root`@`%` PROCEDURE `test_shiwu`(
p_id INT,
p_Name VARCHAR(64),
p_address VARCHAR(64)
)
BEGIN DECLARE t_error VARCHAR(64) DEFAULT 'transaction_ok'; /** 如果出现sql异常,则将t_error设置为'transaction_error'后继续执行后面的操作 */
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error='transaction_error'; -- 出错处理
/** 显式的开启事务,它开启后,事务会暂时停止自动提交*/
START TRANSACTION; INSERT INTO `test2`(`address`) VALUES(p_address); -- 语句1
INSERT INTO `test1`(`id`,`name`) VALUES(p_id,p_Name); -- 语句2 这2个语句都可能引起报错 IF t_error = 'transaction_error' THEN
ROLLBACK; -- 回滚
SELECT t_error; -- 将事务的执行状态返回给被调者
ELSE
COMMIT; -- 提交事务
SELECT '成功了';
END IF; END$$ DELIMITER ;
ok 这样就搞定了,asp.net里面的TransactionOptions 也不需要使用了
我们可以看到在刚才的mysql存储过程里面,是有2个语句,其中的任意一个语句执行报错的话,都会引起回滚操作.
下面再来一个非常特殊 的情况,我们把刚才的那2个语句,换成另外一个存储过程(因为有时候,我们写sql,不止是2个sql语句,可能是更多,那么我们就需要封装到其他的存储过程里面)
DELIMITER $$ USE `test`$$ DROP PROCEDURE IF EXISTS `test_shiwu`$$ CREATE DEFINER=`root`@`%` PROCEDURE `test_shiwu`(
p_id INT,
p_Name VARCHAR(64),
p_address VARCHAR(64)
)
BEGIN DECLARE t_error VARCHAR(64) DEFAULT 'transaction_ok'; /** 如果出现sql异常,则将t_error设置为'transaction_error'后继续执行后面的操作 */
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error='transaction_error'; -- 出错处理
/** 显式的开启事务,它开启后,事务会暂时停止自动提交*/
START TRANSACTION; -- INSERT INTO `test2`(`address`) VALUES(p_address); -- 语句1
-- insert into `test1`(`id`,`name`) values(p_id,p_Name); -- 语句2 这2个语句都可能引起报错 CALL test_shiwu_desc(p_id,p_Name,p_address); -- 这个存储过程里面就只有上面的2个sql语句而已 IF t_error = 'transaction_error' THEN
ROLLBACK; -- 回滚
SELECT t_error; -- 将事务的执行状态返回给被调者
ELSE
COMMIT; -- 提交事务
SELECT '成功了';
END IF; END$$ DELIMITER ;
经过测试,在一个存储过程A里面,如果有事务,事务里面又包含另外一个存储过程B的话,是可以执行的.
也就是说 如果B执行失败,也是会让A进行回滚的.
最后,我们到asp.net里面,对返回的值进行判断就可以了
string temp = jkController.Changepoint(mobile, actionType, actionId, point);
if (temp == "transaction_error")
{
throw new MessageJxtException(Message.操作失败本次操作没有执行);
}
else if (temp == "already_login")
{
throw new MessageJxtException(Message.一天只能获取一次登陆积分);
}
else if (temp == "already_vote")
{
throw new MessageJxtException(Message.一个投票只能获取一次投票积分);
}
else
{
outPoint = Convert.ToInt32(temp);
}
mysql 存储过程 事务; mysql的事务中包含一个存储过程的更多相关文章
- 分别应用include指令和include动作标识在一个jsp页面中包含一个文件。
分别应用include指令和include动作标识在一个jsp页面中包含一个文件. hello.jsp <%@ page language="java" import=&qu ...
- mysql 线上not in查询中的一个坑
今天早上开发又过来说,怎么有个语句一直没有查询出结果,数据是有的呀,并发来了如下的sql(为了方法说明,表名及查询均做了修改): select * from t2 where t2.course no ...
- 利用JS将页面中包含“一个”字段值的元素改为红色
document.body.innerHTML = document.body.innerHTML.replace(/一个/ig,"<span style='color: red;'& ...
- Perl语言入门:第七章习题:输出文件中包含一个大写字母的所有行,不输出一行的内容全是大写的
文件内容: bash-2.03$ cat file_4_ex_ch7.txt anonymous attribute demolition grammar rules indices refernce ...
- jsp 中包含 一个路径为变量的文件
<head> <base href="<%=basePath%>"> <% String fileroot="MyJsp.jsp ...
- MySQL必知必会笔记(六)存储过程 游标 触发器
留印:http://blog.sina.com.cn/s/articlelist_1254871964_5_1.html 第二十三章 使用存储过程 MySQL5 中添加了存储过程的支持. ...
- 数据库程序接口——JDBC——功能第四篇——事务之Spring事务
综述 事务的实现方式有三种,JTA,Spring事务,Web Container方式.本篇讲述Spring事务. Spring事务分为两个部分核心对象,Spring事务的实现方式. Spring事务实 ...
- SQL Server 在多个数据库中创建同一个存储过程(Create Same Stored Procedure in All Databases)
一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 遇到的问题(Problems) 实现代码(SQL Codes) 方法一:拼接SQL: 方法二: ...
- Ext中包含了几个以get开头的方法
Ext中包含了几个以get开头的方法,这些方法可以用来得到文档中DOM.得到当前文档中的组件.得到Ext元素等,在使用中要注意区别使用.1.get方法get方法用来得到一个Ext元素,也就是类型为Ex ...
随机推荐
- eclipse运行WordCount
1) 可以完全参考http://www.cnblogs.com/archimedes/p/4539751.html在eclipse下创建MapReduce工程,创建了MR工程,并完成WordCount ...
- c# 获取mac地址的2种方法
和大家分享下,互相学习一下吧.第一个获取方法好像获取不到mac地址,我用了第二种方法可以获取到.希望知道的可以说下为什么. 1,首先要添加引用:using System.Management; 2,代 ...
- 查看w3wp进程占用的内存及.NET内存泄露,死锁分析--转载
一 基础知识 在分析之前,先上一张图: 从上面可以看到,这个w3wp进程占用了376M内存,启动了54个线程. 在使用windbg查看之前,看到的进程含有 *32 字样,意思是在64位机器上已32位方 ...
- ZOJ3718 Diablo II(状态压缩dp)
题意:一个人物有K(K<=7)种技能,每种技能都有bi,ci,di值,表示该技能不能点超过bi次,每点一次加ci,点满bi次有一个附加得分di.然后还有N件武器,武器本身会有能力加成,然后每个武 ...
- POJ 2041
#include <iostream> #include <string> #include <algorithm> using namespace std; st ...
- login shell 和 non-login shell 的区别
介绍之前先思考一个问题:有时我们通过su命令切换用户后,却发现并没有进入该用户的shell环境.这是为什么? login shell:取得bash时需要完整的登录流程.就是说通过输入账号和密码登录系统 ...
- WCF分布式开发步步为赢(6):WCF服务契约继承与分解设计
上一节我们学习了WCF分布式开发步步为赢(5)服务契约与操作重载部分.今天我们来继续学习WCF服务契约继承和服务分解设计相关的知识点.WCF服务契约继承有何优势和缺点?实际项目里契约设计有什么原则和依 ...
- tvm install
一.系统需求:1.可以访问互联网2.关闭防火墙和selinux 二.安装步骤(进入软件包所在目录):1.rpm -ivh daemontools-0.76-1.el6.x86_64.rpm2.yum ...
- 配置IIS应用程序池
IIS 6的核心在于工作进程隔离模式,而应用程序池则是定义工作进程如何进行工作,因此,可以说应用程序池是整个IIS 6的核心. 和IIS 5中只能使用单个应用程序池不同,工作在工作进程隔离模式的IIS ...
- eq相等 ,ne、neq不相等 EL表达式
eq相等,ne.neq不相等, gt大于, lt小于 gte.ge大于等于 lte.le 小于等于 not非 mod求模 is [not] div by是否能被某数整除 is [n ...