C#事务
来源:互联网 发布:mac 酷狗不能播放flac 编辑:程序博客网 时间:2024/06/10 10:32
<1>
拿转账来说,当你给张三转账时,只有给张三转账成功,并且张三成功收到钱,这才算完成了一个事务,否则事务就是失败的。 事务就是要求,这几步操作必须同时成功,只要有任何一个失败,就全失败了,必须所有成功才能成功。
事务只有两种结果,一种是提交,一种是回滚。 即:成功就提交事务,失败就回滚。
平常我们在sql server里面执行一条insert语句,执行完毕后,我们也没有手动执行commit来提交事务,可是它却将数据插入到数据库中了,这是为什么呢? 答案:那是因为sql server默认是自动提交事务,当你执行一条sql 语句的时候,如果执行成功,它就自动给你commit来提交事务了,如果失败了就自动给你回滚了
下面我们来看看手动开启事务。(注意手动开启事务,就必须要手动commitl来提交事务,和手动回滚事务)
C# 执行SQL事务 又两种方法(本人总结的)
1.通过存储过程。
2.通过C#中提供的 Transaction 。 现在就就演示一下通过C#中提供的Transaction 执行SQL事务。
WebForm3.aspx.cs页面
using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.UI;using System.Web.UI.WebControls;using System.Configuration;using System.Data.SqlClient;namespace 用户激活{ public partial class WebForm3 : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } protected void Button1_Click(object sender, EventArgs e) { string connStr=ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString; using(SqlConnection conn=new SqlConnection(connStr)) { conn.Open(); using (SqlTransaction tran = conn.BeginTransaction()) //开始数据库事务。即创建一个事务对象tran { using (SqlCommand cmd =new SqlCommand()) { cmd.Connection = conn; cmd.Transaction = tran; //获取或设置将要其执行的事务 try { //在try{}块里执行sqlconnection命令 cmd.CommandText = "update bb set Moneys=Moneys-" + Money.Text + " where ID=" + ToID.Text; cmd.ExecuteNonQuery(); cmd.CommandText = "update bb set Moneys=Moneys+" + Money.Text + " where ID=" + FromID.Text; cmd.ExecuteNonQuery(); tran.Commit(); //如果两条sql命令都执行成功,则执行commit这个方法来执行这些操作。 Msg.Text = "转账成功"; } catch { Msg.Text = "转账失败"; tran.Rollback();//如果执行不成功,发送异常,则执行rollback方法,回滚到事务操作开始之前。 } } } } } }}
<>
WebForm3.aspx页面
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm3.aspx.cs" Inherits="用户激活.WebForm3" %><html xmlns="http://www.w3.org/1999/xhtml"><head id="Head1" runat="server"> <title></title></head><body> <form id="form1" runat="server"> 转账账户:<asp:TextBox ID="ToID" runat="server"></asp:TextBox></br> 接收账户:<asp:TextBox ID="FromID" runat="server"></asp:TextBox></br> 转账金额:<asp:TextBox ID="Money" runat="server"></asp:TextBox></br> 转账是否成功:<asp:Label ID="Msg" runat="server" Text=""></asp:Label></br> <asp:Button ID="Button1" runat="server" Text="提交转账" onclick="Button1_Click" /> </form></body></html>
0 0
- C#事务
- C#事务
- C#事务
- C#事务
- C#事务
- c# 事务
- c# 事务
- C#事务
- C# 事务
- C# 事务
- C# 事务学习
- C#数据库事务控制
- C#执行事务
- c#执行事务方法
- c#执行事务
- c#事务例子
- c# 业务层事务
- C#中事务
- Rabbitmq集群高可用测试
- Largest Number
- android使用toast时应用getApplicationContext()作为参数
- 加载xib文件,如果想在初始化的时候就添加点东西就重载-(id)initWithCoder:(NSCoder *)aDecoder
- Python连接MySQL及对其操作
- C#事务
- android library project使用
- 2014年11月工作总结
- Android原理揭秘系列之View、ViewGroup
- (转)Android 中 getApplicationContext()、this、getApplication()之间的区别
- JSON 语法
- RabbitMQ之队列与消息持久化
- vGate共享存储不小心被格式化了如何修复
- Android学习(11)-文件和SharedPreference存储