zoukankan      html  css  js  c++  java
  • C# 事务

    在执行sql语句或存储过程时,为了避免执行出错,对数据库进行错误修改。为sql语句加上事务,出错时回滚。

    两种方法:

    一:在C# 代码中加事务例如

    public static int UpdatePassWord(UserModel userModel)
           {
               int num = 0;
               OleDbConnection Conn = DBHelper.Connection;
               OleDbCommand Comm = new OleDbCommand("", Conn);
               OleDbTransaction trans = Conn.BeginTransaction();
               Comm.Transaction = trans;
               try
               {
                   string sql = "UPDATE Users1 SET [PassWord]=@PassWord where LoginName = @LoginName";
    
                   OleDbParameter[] paras ={
                                           
                                         new OleDbParameter("@password",Translate.Encrypt(userModel.PassWord)),
                                         new OleDbParameter("@loginname",Translate.Encrypt(userModel.LoginName)),
                                        };
                   //int num = DBHelper.ExecuteCommand(sql, pares);
                   //return num;
                   Comm.CommandText = sql;
                   Comm.Parameters.AddRange(paras);
                   num = Comm.ExecuteNonQuery();
                   if (num == 0)
                       throw new Exception("保存出错,稍后重试");
                   trans.Commit();
               }
               catch (Exception ex)
               {
                   trans.Rollback();
                   num = 0;
               }
               finally
               {
                   Conn.Close();
               }
               return num;
           }

    二:在存储过程中加事物,例如

    set ANSI_NULLS ON
    set QUOTED_IDENTIFIER ON
    GO
    
    
    ALTER PROCEDURE [dbo].[PosKind_Add]
    (
    @kind varchar(100),
    @number varchar(50),
    @ShowOrder int
    )
     AS
    declare @CurrentError int
    begin transaction
    
    insert into PosKind(kind,number,ShowOrder)Values(@kind,@number,@ShowOrder)
    
    
    select @CurrentError = @@Error
    if @CurrentError != 0
    begin
    rollback transaction
    goto ErrorHead
    end
    commit transaction
    
    ErrorHead:
    
    return 
  • 相关阅读:
    数据结构与算法
    ROS 机器人技术
    我常用的 VSCode C:C++ 插件!
    Ubuntu 常用的录屏、截图、Gif 软件!
    从 0 开始机器学习
    Word 设置页码从指定页开始的详细步骤!
    Ubuntu16.04 更新 ruby-2.6!
    配置 Git 不用每次 push 都输入密码!
    解决 rubygems.org 无法访问的问题!
    PHP 反序列化漏洞入门学习笔记
  • 原文地址:https://www.cnblogs.com/chiyueqi/p/2914176.html
Copyright © 2011-2022 走看看