C#中事务处理和非事务处理方法实例分析

 更新时间:2015年07月16日 15:00:45   作者:罪恶的花生  
这篇文章主要介绍了C#中事务处理和非事务处理方法,较为详细的分析了C#中事务处理与非事务处理的使用技巧,对于使用C#进行数据库程序开发有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了C#中事务处理和非事务处理方法。分享给大家供大家参考。具体如下:

C#代码如下:

String connectionString = ConfigurationManager.ConnectionStrings["DB_Constr"].ToString();
SqlConnection conn = null;
SqlTransaction trans = null;
try {
 conn = new SqlConnection(connectionString);
 if (conn.State != ConnectionState.Open) conn.Open();
 //开启事务,可以指定事无级别。默认为提交才可以查询
 trans = conn.BeginTransaction();
 //save(conn, trans);
 DbUtils.commit(trans);
} catch (Exception ex) {
 DbUtils.rollback(trans);
 ClientScript.RegisterStartupScript(this.GetType(), "错误提示", "<script>alert('" + StringUtil.toJsStr(ex.Message) + "');</script>");
} finally {
 DbUtils.closeQuietly(conn, trans);
}
String connectionString = ConfigurationManager.ConnectionStrings["DB_Constr"].ToString();
SqlConnection conn = null;
try {
 conn = new SqlConnection(connectionString);
 if (conn.State != ConnectionState.Open) conn.Open();
} catch (Exception ex) {
 ScriptManager.RegisterStartupScript(this, this.GetType(), "mess", "<script>alert('"+StringUtil.toJsStr(ex.Message)+"')</script>", false);
} finally {
 DbUtils.closeQuietly(conn);
}

StringUtil.cs如下:

using System;
using System.Collections.Generic;
using System.Text;
namespace Tools{
 public sealed class StringUtil {
  public static bool isEmpty(String str) {
   if (str == null) return true;
   if (str.Length == 0) return true;
   if (str == String.Empty) return true;
   return false;
  }
  public static bool isNotEmpty(String str) {
   return !isEmpty(str);
  }
  public static String toJsStr(String str) {
   str = str.Replace("'", "\\'");
   str = str.Replace("\r", "");
   str = str.Replace("\n", "\\n");
   return str;
  }
  public static void Main() {
   Console.Write(isNotEmpty(null));
   Console.Read();
  }
 }
}

DbUtils.cs如下:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data.SqlClient;
using System.Data;
namespace Tools{
 public class DbUtils {
  public static SqlConnection getConnection(string connectstr) {
   SqlConnection conn = new SqlConnection(connectstr);
   if (conn.State != ConnectionState.Open) {
    conn.Open();
   }
   return conn;
  }
  public static void closeQuietly(SqlConnection conn) {
   try {
    close(conn);
   } catch { }
  }
  public static void closeQuietly(SqlTransaction trans) {
   try {
    close(trans);
   } catch { }
  }
  public static void close(SqlConnection conn) {
   if (conn != null) {
    conn.Close();
    conn.Dispose();
   }
  }
  public static void close(SqlTransaction trans) {
   if (trans != null) {
    trans.Dispose();
   }
  }
  public static void closeQuietly(SqlConnection conn, SqlTransaction trans) {
   closeQuietly(trans);
   closeQuietly(conn);
  }
  public static void commit(SqlTransaction trans) {
   try {
    if(trans!=null) trans.Commit();
   } catch{ }
  }
  public static void rollback(SqlTransaction trans) {
   try {
    if (trans != null) trans.Rollback();
   } catch { }
  }
 }
}

希望本文所述对大家的C#程序设计有所帮助。

相关文章

  • C#值类型和引用类型的深入理解

    C#值类型和引用类型的深入理解

    本篇文章主要是对C#中值类型和引用类型进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • 用C#+Selenium+ChromeDriver爬取网页(模拟真实的用户浏览行为)

    用C#+Selenium+ChromeDriver爬取网页(模拟真实的用户浏览行为)

    这篇文章主要介绍了用C#+Selenium+ChromeDriver爬取网页,模拟真实的用户浏览行为,需要的小伙伴可以参考一下
    2022-01-01
  • C#/.Net开发chatGPT、openAI的简单步骤

    C#/.Net开发chatGPT、openAI的简单步骤

    OpenAI处于科技行业下一件大事件的最前沿,具有初创公司史诗般的标志,下面这篇文章主要给大家介绍了关于C#/.Net开发chatGPT和openAI的相关资料,需要的朋友可以参考下
    2023-02-02
  • C#封装DBHelper类

    C#封装DBHelper类

    DBHelper类是用类将ADO.NET用方法封装起来,用以减少程序员的工作量。本文为大家提供一个C#封装的DBHelper类,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • WinForm实现读取Resource中文件的方法

    WinForm实现读取Resource中文件的方法

    这篇文章主要介绍了WinForm实现读取Resource中文件的方法,很实用的一个功能,需要的朋友可以参考下
    2014-08-08
  • C#实现简单的计算器功能(窗体)

    C#实现简单的计算器功能(窗体)

    这篇文章主要为大家详细介绍了C#实现简单的计算器功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • C#控制台模拟电梯工作原理

    C#控制台模拟电梯工作原理

    简单的模拟一下电梯的运行,电梯内部和外部楼层呼叫的优先级判断。以前学硬件的时候做这个不成问题,现在用软件来模拟对我来说比较难,要C#的图形界面。求高手赐教。
    2015-06-06
  • 如何搭建新的WPF项目框架

    如何搭建新的WPF项目框架

    这篇文章主要介绍了如何搭建新的WPF项目框架,在项目开发中比较常见的开发模式就是MVVM模式,使用MVVM框架开发好处:1、框架较轻,2、学习成本低、3、适用大多数中小型项目,4、相对于微软的prism框架更容易上手,需要的朋友可以参考下
    2015-07-07
  • C#中字符串合并的多种实现方法

    C#中字符串合并的多种实现方法

    字符串合并是将两个或多个字符串组合成一个单一字符串的过程,在项目开发中非常常见,C#也为我们提供非常多字符串合并方式,下面一起盘点下,感兴趣的小伙伴跟着小编一起来看看吧
    2025-01-01
  • C#实现合并多张图片为GIF动态图

    C#实现合并多张图片为GIF动态图

    这篇文章主要为大家详细介绍了C#如何将把一张又一张的图片去拼合成一张GIF动态图片,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2022-12-12

最新评论