日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql有三种事务模式_MySQL之事务与三大范式

發布時間:2025/3/13 数据库 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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之事务与三大范式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。