在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的事务中包含一个存储过程的更多相关文章

  1. 分别应用include指令和include动作标识在一个jsp页面中包含一个文件。

    分别应用include指令和include动作标识在一个jsp页面中包含一个文件. hello.jsp <%@ page language="java" import=&qu ...

  2. mysql 线上not in查询中的一个坑

    今天早上开发又过来说,怎么有个语句一直没有查询出结果,数据是有的呀,并发来了如下的sql(为了方法说明,表名及查询均做了修改): select * from t2 where t2.course no ...

  3. 利用JS将页面中包含“一个”字段值的元素改为红色

    document.body.innerHTML = document.body.innerHTML.replace(/一个/ig,"<span style='color: red;'& ...

  4. Perl语言入门:第七章习题:输出文件中包含一个大写字母的所有行,不输出一行的内容全是大写的

    文件内容: bash-2.03$ cat file_4_ex_ch7.txt anonymous attribute demolition grammar rules indices refernce ...

  5. jsp 中包含 一个路径为变量的文件

    <head> <base href="<%=basePath%>"> <% String fileroot="MyJsp.jsp ...

  6. MySQL必知必会笔记(六)存储过程 游标 触发器

    留印:http://blog.sina.com.cn/s/articlelist_1254871964_5_1.html   第二十三章 使用存储过程     MySQL5 中添加了存储过程的支持. ...

  7. 数据库程序接口——JDBC——功能第四篇——事务之Spring事务

    综述 事务的实现方式有三种,JTA,Spring事务,Web Container方式.本篇讲述Spring事务. Spring事务分为两个部分核心对象,Spring事务的实现方式. Spring事务实 ...

  8. SQL Server 在多个数据库中创建同一个存储过程(Create Same Stored Procedure in All Databases)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 遇到的问题(Problems) 实现代码(SQL Codes) 方法一:拼接SQL: 方法二: ...

  9. Ext中包含了几个以get开头的方法

    Ext中包含了几个以get开头的方法,这些方法可以用来得到文档中DOM.得到当前文档中的组件.得到Ext元素等,在使用中要注意区别使用.1.get方法get方法用来得到一个Ext元素,也就是类型为Ex ...

随机推荐

  1. js弹出图片原图效果

    1.将js方法独立出来common.js function openwin(src){ var basePath = document.getElementById("basePath&qu ...

  2. CodeSite使用小结 转载

    一.要使用Codesite,需要引用csintf单元二.CodeSite的基本方法(一)AddCheckPoint方法codesite.AddCheckPoint 加入监测点(二)AddSeperat ...

  3. iOS字符串大小转换

    NSString *test = @"Hello World";            // 小写      NSString *lower = [test lowercaseSt ...

  4. HDU 1869 六度分离

    六度分离 http://acm.hdu.edu.cn/showproblem.php?pid=1869 Problem Description 1967年,美国著名的社会学家斯坦利·米尔格兰姆提出了一 ...

  5. SQL技术内幕-10 in和exists 性能比较

    in和exists in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询. 一直以来认为exists比in效率高的说法是不准确的. 如果查询的两 ...

  6. java基础知识回顾之javaIO类---BufferedInputStream和BufferedOutputStream

    MP3的复制过程: package com.lp.ecjtu; import java.io.BufferedInputStream; import java.io.BufferedOutputStr ...

  7. 关于yum仓库的中的软件包下载

    在Linux系统下,很多软件的安装我们都会选择使用yum的方式安装,因为简单方便,易于管理. 有时我们可能会有这样的一个需求:即喜欢上yum仓库中的一个软件了,想要下载到本地.该怎么办呢? 实现方法不 ...

  8. linux中的磁盘的MBR记录详解

    在硬盘中,硬盘的0柱面0磁头第一个1扇区称为主引导扇区,也叫主引导记录-MBR(main boot record),其中MBR是以下三个部分组成 1.Bootloader,主引导程序---446个字节 ...

  9. android listview 加载图片错乱(错位)

       写道 今天晚上一个朋友介绍我看了一篇文章,也是解决android中listview在加载图片错位的问题,看了之后,感觉写的很好,自己也遇到这个问题,但是又不知道从何下手,看到这篇文章后,我的问题 ...

  10. iOS开发--iOS及Mac开源项目和学习资料

    文/零距离仰望星空(简书作者)原文链接:http://www.jianshu.com/p/f6cdbc8192ba著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 原文出处:codecl ...