淺談.net中數據庫操作事務
.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中數據庫操作事務