mysql有三种事务模式_MySQL之事务与三大范式
一、MySQL事務
在MySQL中將一組有序的增刪改操作看做一個獨立的執行單元,當這一組所有的操作都成功,事務執行成功,如果其中有一個操作失敗,事務執行回滾。MySQL 事務主要用于處理操作量大,復雜度高的數據。
注意:
在 MySQL 中只有使用了 Innodb 數據庫引擎的數據庫或表才支持事務。
事務處理可以用來維護數據庫的完整性,保證成批的 SQL 語句要么全部執行,要么全部不執行。
事務用來管理 insert,update,delete 語句
一般來說,事務是必須滿足4個條件(ACID):原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)、持久性(Durability)。
原子性:事務被作為最小的執行單元,不可分割。
一致性:主要描述事務的狀態,事務執行前和執行后的狀態要保持一致。
隔離性:多個用戶并發訪問數據庫時,數據庫會給每個用戶開啟一個事務,事務和事務之間相互隔離,互不影響。
持久性:一旦事務執行成功,對于數據的影響會被永久性的存儲在數據庫中。
事務的回滾:即恢復到事務開始之前的狀態。
如果不考慮事務的隔離性的話,可能會發生的狀態:
臟讀:當一個事務使用了?另一個未提交事務的數據。
不可重復讀:當一個事務重復讀取一條數據,另一個事務修改了這條數據,導致兩次讀取的結果不一樣。
幻讀:一個事務讀取了多條數據并做了操作(統計,計算),另一個事務修改了其中一條數據,導致操作結果不一樣,就如同出現了幻覺一樣。
在事務之中有四種隔離級別:
讀未提交(Read uncommitted):最低的隔離級別,可能會發生任何情況
讀已提交(Read committed):可以避免臟讀
可重復讀(Repeatable read):可以避免臟讀和幻讀
串行化(Serializable):最高隔離級別,可以避免任何情況發生
事務的隔離級別越高其效率也就越低。
事務的控制語句:
BEGIN 或 START TRANSACTION 顯式地開啟一個事務;
COMMIT 也可以使用 COMMIT WORK,不過二者是等價的。COMMIT 會提交事務,并使已對數據庫進行的所有修改成為永久性的;
ROLLBACK 也可以使用 ROLLBACK WORK,不過二者是等價的。回滾會結束用戶的事務,并撤銷正在進行的所有未提交的修改;
SAVEPOINT identifier,SAVEPOINT 允許在事務中創建一個保存點,一個事務中可以有多個 SAVEPOINT;
RELEASE SAVEPOINT identifier 刪除一個事務的保存點,當沒有指定的保存點時,執行該語句會拋出一個異常;
ROLLBACK TO identifier 把事務回滾到標記點;
SET TRANSACTION 用來設置事務的隔離級別。
在MySQL中事務處理主要有兩種方法:
1、用 BEGIN, ROLLBACK, COMMIT來實現
BEGIN?開始一個事務
ROLLBACK?事務回滾
COMMIT?事務確認
2、直接用 SET 來改變 MySQL 的自動提交模式:
SET AUTOCOMMIT=0?禁止自動提交
SET AUTOCOMMIT=1?開啟自動提交
注:在 MySQL 命令行的默認設置下,事務都是自動提交的,即執行 SQL 語句后就會馬上執行 COMMIT 操作。因此要顯式地開啟一個事務務須使用命令 BEGIN 或 START TRANSACTION,或者執行命令 SET AUTOCOMMIT=0,用來禁止使用當前會話的自動提交。
二、三大范式與反范式
在關系型數據庫中存在三大范式和一個反范式:
第一范式:字段具有原子性。
第二范式:基于第一范式,表中的所有數據都要依賴于主鍵。
第三范式:基于第二范式,主要是描述多表之間的關系,一張表中不能存儲另一張表的非主鍵的值,以避免冗余。
反范式: 允許部分字段冗余 ,降低數據庫查詢的復雜度,提升查詢效率。
總結
以上是生活随笔為你收集整理的mysql有三种事务模式_MySQL之事务与三大范式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql性能测试工具msyqlslap
- 下一篇: python命名空间特性_Python命