事務特性:
1)原子性:事務的所有操作要麼全部成功,要麼全部失敗。
3)隔離性:好比執行緒的鎖,不同使用者同時操作同一張表的資料時,只會為乙個使用者開啟事務,其他使用者則不能在此事務未完成的期間進行對該錶的操作。併發的事務會被相互隔離(由於事務不被提交時可以回滾的。因此事務必須有隔離性,否則修改資料時的事務未被提交,而這時其他使用者看到了修改後的資料,而事務又可能不被提交回滾則會出現(使用者看到的)髒資料)。
4)永續性:事務被提交就不能回滾,修改的資料就是永久性的。
事務的使用細節1:
事務只要提交才會有效,如果不提交則事務內容存在記憶體中,隨時可以回滾。
只要提交才能存入硬碟,被其他使用者讀取。
1)未被提交的事務
1)導致無法讀取到資料庫準確的資料
2)提交事務後
2)提交事務後,能讀取到該次dml操作後的資料。
事務的使用細節2:
a)預設情況下,jdbc會自動提交事務.
b)當執行多條sql語句時,自動提交事務就變的不安全.因此,需要手動管理事務.
c)需要關閉事務的自動提交,並在事務成功時進行提交,失敗或發生異常時進行回滾,保證事務的一致性.
比如:乙個a使用者轉賬給b使用者,由於jdbc的預設自動提交則會,在a使用者操作異常則可能導致a使用者的錢減少了,而b的錢沒有增加的不一致性。
這種情況就不能把a使用者扣錢和b使用者加錢分成2個單獨的事務,必須把2個事務合併成乙個事務。把jdbc設定我i手動提交,2個操作全部完成(即事務成功)則提交,否則回滾。
刪除oracle未提交的事務
先查詢出未提交的事務 select dob.object name table name,lo.session id vss.serial 刪除號,lo.locked mode,lo.session id,vss.serial vss.action action,vss.osuser osuser,...
mysql檢視未提交的事務程序
查詢 正在執行的事務 select from information schema.innodb trx 檢視正在鎖的事務 select from information schema.innodb locks 檢視等待鎖的事務 select from information schema.inno...
mysql查詢未提交事務的sql語句
mysql查詢未提交事務的sql語句,找出未提交事務執行的sql語句 mysql開啟事務後沒有提交就退出,事務長時間running狀態,程序又處於sleep狀態,有可能後續導致其他事物超時失敗 能找到事物執行的sql語句的話就很容易定位到程式中錯誤的 檢視所有事務 檢視程序資訊 查詢程序狀態,發現s...