C#编程之事务用法

 更新时间:2015年11月18日 10:37:28   作者:mile  
这篇文章主要介绍了C#编程之事务用法,结合实例形式对比分析了C#中事务提交与回滚的具体实现技巧与相关注意事项,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了C#编程之事务用法。分享给大家供大家参考,具体如下:

ado.net2.0的SqlTransaction使用方法

/////ado.net1.0中使用Transacation(事务)
string connectionString = "database=Northwind;pwd=admin;uid=sa;server=DATABASE-VPC\\SQL2005";
using (SqlConnection conn = new SqlConnection(connectionString))
{
  conn.Open();
  SqlTransaction transaction = conn.BeginTransaction();
  try
  {
   using (SqlCommand cmd = new SqlCommand())
   {
    cmd.Connection = conn;
    cmd.CommandType = CommandType.Text;
    cmd.CommandText = "";
    cmd.Transaction = transaction;
    cmd.ExecuteNonQuery();
    transaction.Commit();//提交事务
   }
  }
  catch
  {
   transaction.Rollback();//事务回滚
  }
/////2.0中使用事务
string connectionString = "database=Northwind;pwd=admin;uid=sa;server=DATABASE-VPC\\SQL2005";
string connectionStringTwo = "database=Test;pwd=admin;uid=sa;server=DATABASE-VPC\\SQL2005";
using (TransactionScope transaction = new TransactionScope())//使用事务
{
  try
  {
   using (SqlConnection conn = new SqlConnection(connectionString))
   {
    using (SqlCommand cmd = new SqlCommand())
    {
     cmd.CommandText = "insert into [member] (name) values ('test')";
     cmd.CommandType = CommandType.Text;
     cmd.Connection = conn;
     conn.Open();
     cmd.ExecuteNonQuery();
    }
   }
   using (SqlConnection conn = new SqlConnection(connectionStringTwo))
   {
    using (SqlCommand cmd = new SqlCommand())
    {
     cmd.CommandText = "insert into [member] (name) values ('test')";
     cmd.CommandType = CommandType.Text;
     cmd.Connection = conn;
     conn.Open();
     cmd.ExecuteNonQuery();
    }
   }
   transaction.Complete();//就这句就可以了。
  }
  catch (Exception ex) { MessageBox.Show(ex.Message); }
}

ado.net1.0与ado.net2.0中对比

1.0中不能跨数据库,速度慢
2.0中可以跨数据库,2.0中不再使用com+,速度比1.0快50%(因为它不用把大量的时间消耗在查找在com+中)
2.0中的事务会自动判断使用何种事务(不用您考虑是简单事务还是分部式事务)。
2.0中的Transactions新添加了命名空间。没有com+注册和com+的开销。

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

相关文章

  • C#画图之饼图折线图的实现方法

    C#画图之饼图折线图的实现方法

    这篇文章主要介绍了C#画图之饼图折线图的实现方法,以实例形式讲述了C#画图的完整实现过程,是非常实用的技巧,有不错的借鉴价值,需要的朋友可以参考下
    2014-09-09
  • C# 语言入门基础介绍

    C# 语言入门基础介绍

    这篇文章主要介绍了C# 语言入门基础,c#是一种新式编程语言,不仅面向对象,还类型安全,本教程概述了 C# 8 及更高版本中该语言的主要组件。 下面一起进入文章了解更多的详细内容吧
    2021-12-12
  • Unity实现俄罗斯方块(二)

    Unity实现俄罗斯方块(二)

    这篇文章主要为大家详细介绍了Unity实现俄罗斯方块的第一部分代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • C# 制作PictureBox圆形头像框并从数据库中读取头像

    C# 制作PictureBox圆形头像框并从数据库中读取头像

    C#提供的PictureBox控键默认情况下是方形的非常大的影响美观,怎么解决这一问题呢?下面小编给大家带来了C# 制作PictureBox圆形头像框并从数据库中读取头像的操作代码,感兴趣的朋友一起学习下吧
    2021-08-08
  • C#实现WPF项目复制和移动文件夹

    C#实现WPF项目复制和移动文件夹

    这篇文章介绍了C#实现WPF项目复制和移动文件夹的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C#截取中英文混合指定长度字符串实例

    C#截取中英文混合指定长度字符串实例

    这篇文章主要介绍了C#截取中英文混合指定长度字符串,大家参考使用
    2013-12-12
  • C# 中的"智能枚举"之如何在枚举中增加行为(示例代码)

    C# 中的"智能枚举"之如何在枚举中增加行为(示例代码)

    这篇文章主要介绍了C# 中的“智能枚举”之如何在枚举中增加行为(示例代码),智能枚举跟设计模式的意义一样,可以帮助您避免重复的代码,并提高代码的可读性和可维护性,需要的朋友可以参考下
    2023-05-05
  • Parallel.For循环与普通for循环的性能比较

    Parallel.For循环与普通for循环的性能比较

    这篇文章介绍了Parallel.For循环与普通for循环的性能比较,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • C#实现异步编程的方法

    C#实现异步编程的方法

    这篇文章主要为大家详细介绍了C#实现异步编程的方法,什么是异步,如何实现异步编程,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • C#调用usb摄像头的实现方法

    C#调用usb摄像头的实现方法

    这篇文章主要介绍了C#调用usb摄像头的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02

最新评论