淺談.net中事務

.net中的事務 關鍵幾點 sql

概念:1:什麼是事務數據庫

       2:何時用事務編程

       3:基本的語法併發

(1):編程語言

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

例如:在關係數據庫中,一個事務能夠是一條SQL語句,一組SQL語句或整個程序。atom

特性.net

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

  事務應該具備4個屬性:原子性、一致性、隔離性、持續性。這四個屬性一般稱爲ACID特性。ci

  原子性(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; }

相關文章
相關標籤/搜索