sqlserver中在存储过程中写事务

由于对数据的操作经常需要并发,所以在存储过程中使用事务是非常必要的,我经常这样处理:

if (exists (select * from sys.objects where name = ' sp_**** '))

    drop proc sp_****

go

CREATE PROCEDURE sp_****

参数列表....

@out bit=0 output  --输出参数

AS

BEGIN

set nocount on

begin tran
--数据库 增 改 删

if @@rowcount!=0

begin

commit

set @out=1

end

else

begin

rollback

set @out=0

end

set nocount off

END

下面说调用

方法很多:
一、用system.transactions
二、用存储过程,把事务写在存储过程中,在代码中传递参数,调用存储过程。
三、代码:

        public static int ExecuteSqlTran(List<String> SQLStringList)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                conn.Open();
                SqlCommand cmd = new SqlCommand();
                cmd.Connection = conn;
                SqlTransaction tx = conn.BeginTransaction();
                cmd.Transaction = tx;
                try
                {
                    int count = 0;
                    for (int n = 0; n < SQLStringList.Count; n++)
                    {
                        string strsql = SQLStringList[n];
                        if (strsql.Trim().Length > 1)
                        {
                            cmd.CommandText = strsql;
                            count += cmd.ExecuteNonQuery();
                        }
                    }
                    tx.Commit();
                    return count;
                }
                catch
                {
                    tx.Rollback();
                    return 0;
                }
            }
        }

另外有单独介绍sqlserver存储过程的文章,写得不错

http://www.cnblogs.com/hoojo/archive/2011/07/19/2110862.html

转载于:https://www.cnblogs.com/ygyxinyu/archive/2013/02/20/2919426.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值