C#事务

本文介绍了如何在C#中通过存储过程和Transaction类执行SQL事务,包括手动开启、提交和回滚事务的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<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>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值