1. 程式人生 > >淺談.net中數據庫操作事務

淺談.net中數據庫操作事務

並發執行 atomic 簡單的 mce 錯誤 ons nbsp 高級 相關

.net中的事務 關鍵幾點

概念:1:什麽是事務

2:什麽時候用事務

3:基本的語法

(1):

事務(Transaction)是訪問並可能更新數據庫中各種數據項的一個程序執行單元(unit)。事務通常由高級數據庫操縱語言或編程語言(如SQL,C++或Java)書寫的用戶程序的執行所引起,並用形如begin transaction和end transaction語句(或函數調用)來界定。事務由事務開始(begin transaction)和事務結束(end transaction)之間執行的全體操作組成。

例如:在關系數據庫中,一個事務可以是一條SQL語句,一組SQL語句或整個程序。

特性

  事務是恢復和並發控制的基本單位。

  事務應該具有4個屬性:原子性、一致性、隔離性、持續性。這四個屬性通常稱為ACID特性。

  原子性(atomicity)。一個事務是一個不可分割的工作單位,事務中包括的操作要麽都做,要麽都不做。

  一致性(consistency)。事務必須是使數據庫從一個一致性狀態變到另一個一致性狀態。一致性與原子性是密切相關的。

  隔離性(isolation)。一個事務的執行不能被其他事務幹擾。即一個事務內部的操作及使用的數據對並發的其他事務是隔離的,並發執行的各個事務之間不能互相幹擾。

  持久性(durability)。持續性也稱永久性(permanence),指一個事務一旦提交,它對數據庫中數據的改變就應該是永久性的。接下來的其他操作或故障不應該對其有任何影響。

(2):事物一般用在並發操作多張表的時候使用,用於保證用戶的數據完整性~

   不需要什麽條件,在對多張關聯表做操作的時候,最好就是加上事物~

(3):開始事物 beginTransaction -----提交事務 Commit() ----錯誤回滾 Rollback()

簡單的Demo如下 僅供初學者使用 如有不足 盡情見諒

public int Addinfot() {
int res = -1;
string connstr=System.Configuration.ConfigurationManager.AppSettings["connection"];
using (SqlConnection conn = new SqlConnection(connstr))
{
string sql = "insert into userinfo(name,age,salary) values(@name,@age,@salary)";
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.CommandType = CommandType.Text;
conn.Open();
SqlTransaction ts = conn.BeginTransaction(); //開始事務

cmd.Parameters.AddWithValue("@name","張珊");
cmd.Parameters.AddWithValue("@age",30);
cmd.Parameters.AddWithValue("@salary",2300);
try
{
cmd.Transaction = ts;
res = cmd.ExecuteNonQuery();
ts.Commit();//提交事務
cmd.Dispose();
conn.Close();
}
catch
{
ts.Rollback(); //回滾事務
}
}

return res;
}

轉載:淺談.net中事務

淺談.net中數據庫操作事務