zoukankan      html  css  js  c++  java
  • Sql server 事务的两种用法 (转)

    事务(Transaction)是并发控制的单位,是用户定义的一个操作序列。这些操作要么都做,要么都不做,是一个不可分割的工作单位。

    通过事务,SQL Server能将逻辑相关的一组操作绑定在一起,以便服务器保持数据的完整性。
    sql server+ .net 开发环境下,有两种方法能够完成事务的操作,保持数据库的数据完整性;
    一个就是用sql存储过程,另一个就是在ADO.NET中一种简单的事务处理;
    现在通过一个典型的银行转账的例子来说明一下这两个例子的用法
    我们先来看看sql存储过程是如何来完成事务的操作的:
    首先创建一个表:
    create database aaaa --创建一个表,包含用户的帐号和钱数
    go
    use aaaa
    create table bb
    (
     ID int not null primary key,  --帐号
     moneys money    --转账金额
    insert into bb values ('1','2000') --插入两条数据
    insert into bb values ('2','3000')

    用这个表创建一个存储过程:

    create procedure mon --创建存储过程,定义几个变量

    @toID int,    --接收转账的账户

    @fromID int ,  --转出自己的账户

    @momeys money --转账的金额

    as

    begin tran --开始执行事务

    update bb set moneys=moneys-@momeys where ID=@fromID -执行的第一个操作,转账出钱,减去转出的金额

    update bb set moneys=moneys+@momeys where ID=@toID --执行第二个操作,接受转账的金额,增加

    if @@error<>0 --判断如果两条语句有任何一条出现错误

    begin rollback tran –开始执行事务的回滚,恢复的转账开始之前状态

    return 0

    end

    go

    else   --如何两条都执行成功

    begin commit tran 执行这个事务的操作

    return 1

    end

    go


    接下来看看C#.net 是如何调用这个存储过程的:

        protected void Button1_Click(object sender, EventArgs e)

        {

            SqlConnection con =new SqlConnection(@"Data Source=.\SQLEXPRESS;database=aaaa;uid=sa;pwd=jcx"); //连接字符串

            SqlCommand cmd = new SqlCommand("mon",con); //调用存储过程

            cmd.CommandType = CommandType.StoredProcedure;

            con.Open();

            SqlParameter prar = new SqlParameter();//传递参数

            cmd.Parameters.AddWithValue("@fromID", 1);

            cmd.Parameters.AddWithValue("@toID", 2);

            cmd.Parameters.AddWithValue("@momeys",Convert.ToInt32( TextBox1.Text) );

            cmd.Parameters.Add("@return", "").Direction = ParameterDirection.ReturnValue;//获取存储过程的返回值

            cmd.ExecuteNonQuery();

            string value = cmd.Parameters["@return"].Value.ToString();//把返回值赋值给value

            if (value == "1")

            {

                Label1.Text = "添加成功";

            }

            else

            {

                Label1.Text = "添加失败";

           }

    }

    这个也就是在存储过程里添加事务


     

    再来看看不在数据库写sql存储过程,ADO.NET是如何处理事务的:

    protected void Button2_Click(object sender, EventArgs e)

        {

            SqlConnection con = new SqlConnection(@"Data Source=.\SQLEXPRESS;database=aaaa;uid=sa;pwd=jcx");

            con.Open();

            SqlTransaction tran = con.BeginTransaction();//先实例SqlTransaction类,使用这个事务使用的是con 这个连接,使用BeginTransaction这个方法来开始执行这个事务

            SqlCommand cmd = new SqlCommand();

            cmd.Connection = con;

            cmd.Transaction = tran;

            try

            {

                 //try{} 块里执行sqlcommand命令,

                cmd.CommandText = "update bb set moneys=moneys-'" + Convert.ToInt32(TextBox1.Text) + "' where ID='1'";

                cmd.ExecuteNonQuery();

                cmd.CommandText = "update bb set moneys=moneys+' aa ' where ID='2'";

                cmd.ExecuteNonQuery();

                tran.Commit();//如果两个sql命令都执行成功,则执行commit这个方法,执行这些操作

     

                Label1.Text = "添加成功";

            }

            catch

            {

                Label1.Text = "添加失败";

                tran.Rollback();//如何执行不成功,发生异常,则执行rollback方法,回滚到事务操作开始之前;

            }

     

        }

    这就是两个事务不同用法的简单例子,ADO.NET 事务处理的方法看起来比较简单,但是他要使用同一个连接来执行这些操作,要是同时使用几个数据库来用一个事务执行,这样就比较繁琐,但是要是用sql存储过程,这样就相对比较简单,总之是两种方法各有各的优点。

     

    原文地址:http://www.cnblogs.com/zhuifengnianshao/archive/2010/11/24/1886939.html

  • 相关阅读:
    给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
    11
    实战 迁移学习 VGG19、ResNet50、InceptionV3 实践 猫狗大战 问题
    tx2系统备份与恢复
    如何在Ubuntu 18.04上安装和卸载TeamViewer
    bzoj 3732 Network (kruskal重构树)
    bzoj2152 聪聪可可 (树形dp)
    牛客 216D 消消乐 (二分图最小点覆盖)
    牛客 197E 01串
    Wannafly挑战赛23
  • 原文地址:https://www.cnblogs.com/bdf216/p/2627029.html
Copyright © 2011-2022 走看看