C#編程之事務(wù)用法
本文實(shí)例講述了C#編程之事務(wù)用法。分享給大家供大家參考,具體如下:
ado.net2.0的SqlTransaction使用方法
/////ado.net1.0中使用Transacation(事務(wù))
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();//提交事務(wù)
}
}
catch
{
transaction.Rollback();//事務(wù)回滾
}
/////2.0中使用事務(wù)
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())//使用事務(wù)
{
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中對(duì)比
1.0中不能跨數(shù)據(jù)庫(kù),速度慢
2.0中可以跨數(shù)據(jù)庫(kù),2.0中不再使用com+,速度比1.0快50%(因?yàn)樗挥冒汛罅康臅r(shí)間消耗在查找在com+中)
2.0中的事務(wù)會(huì)自動(dòng)判斷使用何種事務(wù)(不用您考慮是簡(jiǎn)單事務(wù)還是分部式事務(wù))。
2.0中的Transactions新添加了命名空間。沒(méi)有com+注冊(cè)和com+的開(kāi)銷。
希望本文所述對(duì)大家C#程序設(shè)計(jì)有所幫助。
相關(guān)文章
WPF輕松實(shí)現(xiàn)進(jìn)度條的示例代碼
WPF中的ProgressBar控件用于表示任務(wù)進(jìn)度,適用于文件下載、數(shù)據(jù)處理等場(chǎng)景,本文將通過(guò)XAML和C#代碼展示如何創(chuàng)建一個(gè)基本的WPF進(jìn)度條,并演示如何通過(guò)事件處理程序更新進(jìn)度條的值來(lái)模擬耗時(shí)操作,感興趣的小伙伴跟著小編一起來(lái)看看吧2024-12-12
.NET使用C#實(shí)現(xiàn)將Word文檔轉(zhuǎn)換為HTML格式
這篇文章主要為大家詳細(xì)介紹了如何在.NET平臺(tái)使用C#將Word文檔轉(zhuǎn)換為HTML文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-01-01
如何利用c#實(shí)現(xiàn)通用守護(hù)進(jìn)程
這篇文章主要給大家介紹了關(guān)于如何利用c#實(shí)現(xiàn)通用守護(hù)進(jìn)程的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用c#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
C#定制Excel界面并實(shí)現(xiàn)與數(shù)據(jù)庫(kù)交互的方法
這篇文章主要介紹了C#定制Excel界面并實(shí)現(xiàn)與數(shù)據(jù)庫(kù)交互的方法的相關(guān)資料,需要的朋友可以參考下2015-11-11
C#后臺(tái)接受前臺(tái)JSON字符串裝換成字典集合處理
本文介紹C#利用Newtonsoft接收前端的JSON字符串,并解析反序列化成字典集合,對(duì)其進(jìn)行處理。2016-04-04

