欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

MySQL事務(wù)是什么

這篇文章將為大家詳細講解有關(guān)MySQL事務(wù)是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)主營左貢網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都app開發(fā),左貢h5重慶小程序開發(fā)公司搭建,左貢網(wǎng)站營銷推廣歡迎左貢等地區(qū)企業(yè)咨詢

MySQL事務(wù)以及事務(wù)隔離級別

MySQL事務(wù)主要用于處理操作量大,復(fù)雜度高的數(shù)據(jù)。比如在人員管理系統(tǒng)中,你刪除一個人員,你就要刪除人員的基本資料,也要刪除和該人員相關(guān)的信息,如信箱,文章等,這些數(shù)據(jù)庫操作語句就構(gòu)成了一個事務(wù)(推薦課程:MySQL教程)

    • MySQL中只有使用了Innodb數(shù)據(jù)庫引擎的數(shù)據(jù)庫或表才支持事務(wù)

    • 事務(wù)處理可以用來維護數(shù)據(jù)庫的完整性,保證成批的SQL語句要么全部執(zhí)行,要么全部不執(zhí)行

    • 事務(wù)用來管理insert,update,delete語句

  • 一般來說,事務(wù)必須滿足4個條件:原子性,一致性,隔離性,持久性

    • 原子性:一個事務(wù)中所有操作,要么全部執(zhí)行,要么全部不執(zhí)行不會結(jié)束在中間某個環(huán)節(jié)。事務(wù)在執(zhí)行過程中發(fā)生錯誤會被回滾到事務(wù)開始前的狀態(tài)

    • 一致性:在事務(wù)開始之前和事務(wù)結(jié)束以后,數(shù)據(jù)庫的完整性沒有被破壞。這表示寫入的資料必須完全符合所有的預(yù)設(shè)規(guī)則,包含資料的精確度,串聯(lián)性以及后續(xù)數(shù)據(jù)庫可以自發(fā)性的完成預(yù)定的工作

    • 隔離性:數(shù)據(jù)庫允許多個并發(fā)事務(wù)同時對其數(shù)據(jù)進行讀寫和修改的能力,隔離性可以防止多個事務(wù)并發(fā)執(zhí)行時由于交叉執(zhí)行而導(dǎo)致數(shù)據(jù)的不一致。事務(wù)隔離分為不同級別,包括讀取未提交內(nèi)容,讀取提交內(nèi)容,可重復(fù)讀和可串行化

    • 持久化:事務(wù)處理結(jié)束后,對數(shù)據(jù)的修改就是永久的,即便系統(tǒng)故障也不會丟失

在MySQL命令行的默認是設(shè)置下,事務(wù)都是自動提交的,即執(zhí)行SQL語句后就會馬上執(zhí)行COMMIT操作。因此要顯式的開啟一個事務(wù)需要使用命令BEGIN或START TRANSACTION,或者執(zhí)行命令SET AUTOCOMMIT=0,用來禁止使用當前繪畫的自動提交

事務(wù)控制語句:

  • BEGIN或START TRANSACTION;顯式地開啟一個事務(wù)

  • COMMIT;也可以使用COMMIT WORK,二者等價的。COMMIT會提交事務(wù),并使已對數(shù)據(jù)庫進行的所有修改成為永久性

  • ROLLBACK;也可以使用ROLLBACK WORK,二者等價。回滾會結(jié)束用戶的事務(wù),并撤回正在進行的所有未提交的修改

  • SAVEPOINT identifier;SAVEPOINT允許在事務(wù)中創(chuàng)建一個保存點,一個事務(wù)可以有多個SAVEPOINT

  • RELESE SAVEPOINT identifier;刪除一個事務(wù)的保存點,當沒有指定的保存點時,執(zhí)行該語句會拋出一個異常

  • ROLLBACK TO identified;把事務(wù)回滾到標記點

  • SET TRANSACTION;用來設(shè)置事務(wù)的隔離級別。InnoDB存儲引擎提供事務(wù)隔離級別有READ UNCOMMITTED,READ COMMITTED,REPEATABLE READ和SERIALIZABLE

MySQL事務(wù)處理主要有兩種方法:

  1. 用BEGIN,ROLLBACK,COMMIT來實現(xiàn)

    • BEGIN開始一個事務(wù)

    • ROLLBACK事務(wù)回滾

    • COMMIT事務(wù)確認

  2. 直接SET來改變MySQL的自動提交模式:

    • SET AUTOCOMMIT=0禁止自動提交

    • SET AUTOCOMMIT=1開啟自動提交

事務(wù)四大特性之一:隔離性

  1. 事務(wù)A跟事務(wù)B之間具有一定的隔離性

  2. read uncommited 讀未提交

    • 在該隔離級別,所有事務(wù)都可以看到其他未提交事務(wù)的執(zhí)行結(jié)果。本隔離級別很少用于實際應(yīng)用。讀取未提交的數(shù)據(jù)稱為臟數(shù)據(jù)

  3. read COMMIT

    • 大多數(shù)數(shù)據(jù)庫系統(tǒng)的默認隔離級別(但不是MySQL)。一個事務(wù)只能看見已經(jīng)提交事務(wù)所作的改變。其避免了臟讀,但仍然存在不可重復(fù)讀和幻讀問題

  4. repeatable read

    • MySQL的默認級別;確保同一事務(wù)的多個實例在并發(fā)讀取數(shù)據(jù)時,會看到同樣的數(shù)據(jù)行。避免了臟讀和不可重復(fù)讀,但是會導(dǎo)致另一個問題:幻讀?;米x是指用戶讀取某一個范圍的數(shù)據(jù)行時,另一個事務(wù)又在該范圍插入了新行,當用戶再讀取該范圍的數(shù)據(jù)行時,會發(fā)現(xiàn)新的幻影行。InnoDB和Falcon存儲引擎通過多版本并發(fā)控制(MVCC)機制解決了該問題

    • 可重復(fù)讀的隔離級別下使用了MVCC機制,select操作不會更新版本號,是快照讀(歷史版本);insert,update和delete會更新版本號,是當前讀(當前版本)

  5. serializable

    • 最高隔離級別,通過強制事務(wù)排序,使之不可能相互沖突,從而解決幻讀問題。簡言之,它是在每個讀的數(shù)據(jù)行上加上共享鎖。在這個級別,可能導(dǎo)致大量的超時現(xiàn)象和鎖競爭

設(shè)置事務(wù)隔離級別

  1. 在my.cnf文件設(shè)置

- READ-UNCOMMITTED
- READ-COMMITED
- REPEATABLE-READ
- SERIALIZABLE
* 例如
[mysqlId]
transaction-isolation = READ-COMMITTED
  1. 通過命令動態(tài)設(shè)置隔離級別

SET [GLOBAL|SESSION] TRANSACTION ISOLATION LEVEL <isolation-level>
其中isolation-level可以是:
- READ UNCOMMITTED
- READ COMMITTED
- REPEATABLE READ
- SERIALIZABLE

GLOBAL|SESSION表示事務(wù)隔離級別的作用范圍:
GLOBAL:表示對所有會話有效
SESSION:表示對當前會話有效

事務(wù)并發(fā)問題

  1. 臟讀:事務(wù)A讀取了事務(wù)B更新的數(shù)據(jù),然后B回滾操作,那么A讀取到的數(shù)據(jù)是臟數(shù)據(jù)

  2. 不可重復(fù)讀:事務(wù)A多次讀取到同一數(shù)據(jù),事務(wù)B在事務(wù)A多次讀取過程中,對數(shù)據(jù)做了更新并未提交,導(dǎo)致事務(wù)A多次讀取同一條數(shù)據(jù),結(jié)果不一致

  3. 幻讀:前后讀取的結(jié)果數(shù)據(jù)條數(shù)不一致。這是因為事務(wù)A的多次讀取過程中,事務(wù)B對表進行插入或刪除操作

關(guān)于MySQL事務(wù)是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

新聞名稱:MySQL事務(wù)是什么
鏈接URL:http://aaarwkj.com/article26/gppejg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、商城網(wǎng)站網(wǎng)站建設(shè)、小程序開發(fā)、網(wǎng)站設(shè)計公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
国产精致成人免费视频| 日本一区二区手机在线| 风间由美亚洲一区二区三区| 亚洲精品福利在线视频| 精品国产美女诱惑久久久| 国产欧美日韩另类在线播放| 邻居少妇扒开腿让我爽了一夜| 久久久久久极精品久久久| 午夜视频在线看一区免费| 天天躁日日躁夜夜躁夜夜| 在线观看国产激情免费视频| 蜜臀人妻久久一区二区三| 国产亚洲无线码一区二区| 91免费观看视频高清| 欧美日韩亚洲一区二区搜索| 日本韩国三级理伦久久久| 亚洲国产高清第一第二区| 日本道二区视频中文字幕| 青青草成人免费在线公开视频| 九九热九九热九九热九| 97视频在线视频免费| 中高龄夫妇五十路六十路| 国产高清不卡一区二区| 五月婷婷六月丁香在线观看| 成人在线一区二区三区观看| 午夜国产激情福利网站| 欧美日韩人美精品一区在线| 亚洲乱码中文字幕人妻| 国产精品超碰在线观看| 久亚洲精品九九久久99 | 欧美日韩国产特级性生活| 日韩一区二区三区视频在线看| 青青草免费视频观看在线| 欧美日韩av在线一区二区| 国产一区二区爽爽爽视频| 18岁以下禁看视频网站| 久久男女激情免费视频| 午夜情色视频在线观看| 国产精品久久久久大屁股精品性色| 国产精品三级国产精品高| 国一区二区三区四区av|