亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL數(shù)據(jù)庫(kù)事務(wù)transaction示例講解教程

 更新時(shí)間:2021年10月26日 17:08:53   作者:數(shù)據(jù)分析與統(tǒng)計(jì)學(xué)之美  
這篇文章主要為大家介紹了MySQL數(shù)據(jù)庫(kù)事務(wù)transaction的示例講解教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步

1、什么是事務(wù)?

在這里插入圖片描述

一個(gè)事務(wù)是一個(gè)完整的業(yè)務(wù)邏輯單元,不可再分。
比如:銀行賬戶(hù)轉(zhuǎn)賬,從A賬戶(hù)向B賬戶(hù)轉(zhuǎn)賬10000,需要執(zhí)行兩條update語(yǔ)句:

update t_act set balance=balance-10000 where actno='act-001';
update t_act set balance=balance+10000 where actno='act-0021';

以上兩條DML語(yǔ)句必須同時(shí)成功,或者同時(shí)失敗,不允許出現(xiàn)一條成功,一條失敗。
要想保證以上的兩條DML語(yǔ)句,同時(shí)成功或者同時(shí)失敗,那么就需要使用數(shù)據(jù)庫(kù)的
“事務(wù)機(jī)制”。

2、和事務(wù)相關(guān)的語(yǔ)句只有這3個(gè)DML語(yǔ)句:insert、delete、update

“為什么只有這3個(gè)DML語(yǔ)句:insert、delete、update?”
因?yàn)樗鼈冞@三個(gè)語(yǔ)句都是和數(shù)據(jù)庫(kù)表中的"數(shù)據(jù)相關(guān)"的。事務(wù)的存在是為了保證數(shù)據(jù)的完整性,安全性。

3、假設(shè)所有的業(yè)務(wù)都能使用1條DML語(yǔ)句搞定,還需要事務(wù)機(jī)制嗎?

不需要事務(wù)。
但實(shí)際情況不是這樣的,通常一個(gè)事兒(“事務(wù)”)需要多條DML語(yǔ)句共同聯(lián)合完成。

4、事務(wù)的原理

在這里插入圖片描述

注意:
一旦提交事務(wù),就會(huì)把歷史操作持久化到硬盤(pán)上去,持久化完成后,清空歷史記錄。
一旦回滾事務(wù),就會(huì)把歷史記錄直接清空掉,而不持久化到硬盤(pán)中。
事務(wù)操作,還可以設(shè)計(jì)保存點(diǎn):了解。

5、事務(wù)的四大特性:ACID

在這里插入圖片描述

事務(wù)包括四大特性:ACID
A原子性:事務(wù)是最小的工作單元,不可再分。
C一致性:事務(wù)必須保證多條DML語(yǔ)句,同時(shí)成功或者同時(shí)失敗。
I隔離性:事務(wù)A與事務(wù)B之間具有隔離。
D持久性:持久性指的是最終數(shù)據(jù)必須持久化到硬盤(pán)文件中,事務(wù)才算成功結(jié)束。

下面對(duì)上述事務(wù)四大特性,進(jìn)行一個(gè)更為詳細(xì)的說(shuō)明
“原子性”:一組操作要么都成功,要么都失敗,這一組操作是不可拆分的。
“一致性”:事務(wù)發(fā)生前后,數(shù)據(jù)總額仍然是匹配的。模擬一個(gè)人給另外一個(gè)人轉(zhuǎn)賬來(lái)說(shuō),轉(zhuǎn)賬之前,2人的金額總和為400;轉(zhuǎn)賬以后,2人的金額總額仍為400。
“隔離性”:所有操作沒(méi)有執(zhí)行完畢之前,其它會(huì)話(huà)窗口不能看見(jiàn)中間數(shù)據(jù)的改變過(guò)程,只有當(dāng)前窗口可以看見(jiàn)數(shù)據(jù)改變過(guò)程。
“持久性”:一旦commit提交后,事務(wù)產(chǎn)生的影響就不能夠撤銷(xiāo)了,已經(jīng)實(shí)實(shí)在在把數(shù)據(jù)修改了。

6、關(guān)于事務(wù)之間的隔離性

"事務(wù)的隔離性存在隔離級(jí)別,理論上隔離級(jí)別包括4個(gè)"
隔離級(jí)別一般都是從2級(jí)、3級(jí)起步,1級(jí)一般用不上。

1)第一級(jí)別:讀未提交(read uncommitted)

  對(duì)方的事務(wù)還沒(méi)有提交,當(dāng)前事務(wù)可以讀取到對(duì)方為提交的數(shù)據(jù)。
   讀未提交存在的問(wèn)題:"臟讀現(xiàn)象",表示讀到了臟數(shù)據(jù)。
   "臟讀":指的是一個(gè)事務(wù)正在修改數(shù)據(jù),但是這種修改并沒(méi)有提交到數(shù)據(jù)庫(kù)。
而另一個(gè)事務(wù),訪問(wèn)到了該數(shù)據(jù),此時(shí)這個(gè)數(shù)據(jù)屬于【臟數(shù)據(jù)】,因而叫臟讀。

2)第二級(jí)別:讀已提交(read committed)

   對(duì)方事務(wù)提交后的數(shù)據(jù),我方可以讀取到。
   這種隔離級(jí)別解決了:臟讀現(xiàn)象沒(méi)有了。
   讀已提交存在的問(wèn)題:不可重復(fù)讀。

3)第三級(jí)別:可重復(fù)讀(repeatable read)

   這種隔離級(jí)別解決了:不可重復(fù)讀問(wèn)題。
   這種級(jí)別存在的問(wèn)題:讀取到的數(shù)據(jù)是幻想,即讀取的是備份數(shù)據(jù)。

4)第四級(jí)別:序列化讀/串行化讀(serializable)

   解決了所有問(wèn)題。
   但是效率低,需要事務(wù)排隊(duì)。

"需要注意的是"
oracle數(shù)據(jù)庫(kù)默認(rèn)的隔離級(jí)別是:讀已提交(第二級(jí)別)。
mysq1數(shù)據(jù)庫(kù)默認(rèn)的隔離級(jí)別是:可重復(fù)讀(第三級(jí)別)。

7、演示事務(wù)的隔離級(jí)別(演示數(shù)據(jù)自己造一些)

1)演示事務(wù)之前,需要掌握的知識(shí)點(diǎn)。

1)mysql默認(rèn)情況下,事務(wù)是自動(dòng)提交的。
2)什么是自動(dòng)提交?
   只要是執(zhí)行任意一條DML語(yǔ)句,則自動(dòng)提交一次。
   因此,在演示事務(wù)之前,必須先關(guān)閉自動(dòng)提交。
   "關(guān)閉自動(dòng)提交語(yǔ)句":start transaction;    
3)"演示事務(wù)需要知道的3條命令:"
   -- 關(guān)閉自動(dòng)提交事務(wù)功能。
   start transaction;
  -- 提交事務(wù)。
  commit;
  -- 回滾事務(wù),只能回滾到上一次的提交點(diǎn)。
  rollback;   

2)設(shè)置全局事務(wù)隔離級(jí)別。

"設(shè)置全局事務(wù)隔離級(jí)別,設(shè)置完成后,退出重新登陸。"
-- 設(shè)置第一級(jí)別
set global transaction isolation level read uncommitted;
-- 設(shè)置第二級(jí)別
set global transaction isolation level read committed;
-- 設(shè)置第三級(jí)別(系統(tǒng)默認(rèn)的事務(wù)級(jí)別,不用設(shè)置)
set global transaction isolation level repeatable read;
--設(shè)置第四級(jí)別
set global transaction isolation level serializable;

"查看全局事務(wù)隔離級(jí)別"
mysql> select @@global.tx_isolation;
+-----------------------+
| @@global.tx_isolation |
+-----------------------+
| REPEATABLE-READ       |
+-----------------------+
1 row in set, 1 warning (0.00 sec)

3)演示讀未提交。

首先,設(shè)置全局事務(wù)隔離級(jí)別。

在這里插入圖片描述

下面進(jìn)行正式的演示:

4)演示讀已提交

首先,設(shè)置全局事務(wù)隔離級(jí)別。

在這里插入圖片描述

下面進(jìn)行正式的演示:

在這里插入圖片描述

5)演示可重復(fù)讀

首先,設(shè)置全局事務(wù)隔離級(jí)別。

在這里插入圖片描述

下面進(jìn)行正式的演示:

在這里插入圖片描述

這個(gè)需要注意:

這里演示的是"可重復(fù)讀",我們?cè)谟疫叴翱谘菔臼聞?wù)的一些列過(guò)程,左邊窗口
根本無(wú)法讀取,左邊窗口讀取到的,始終是原始數(shù)據(jù)的備份數(shù)據(jù)。

怎么理解呢?

你別忘記了,左邊窗口,也是開(kāi)啟事務(wù)功能了的,start transaction;只要
是左邊這個(gè)窗口的事務(wù)功能,沒(méi)有結(jié)束(commit或者rollback都可以結(jié)束事務(wù)),那
么左邊窗口讀取到的,始終是原始數(shù)據(jù)的備份數(shù)據(jù),這就是我們所說(shuō)的"幻想"。任
憑右邊黑窗口中做了任何改變,就算你也提交了事務(wù),我左邊窗口,就是看不到。

左邊黑窗口,要怎么才可以看見(jiàn)這個(gè)變化呢?"

只有左邊這個(gè)黑窗口,先結(jié)束了當(dāng)前黑窗口的事務(wù),重新再次讀取,就可以看
到數(shù)據(jù)是真實(shí)變化了。 

6)演示序列化讀

首先,設(shè)置全局事務(wù)隔離級(jí)別。

在這里插入圖片描述

下面進(jìn)行正式的演示:
第一幅圖:

在這里插入圖片描述

當(dāng)左邊窗口,使用"commit"命令,提交事務(wù)以后,我們?cè)倏从疫叴翱诘淖兓?/p>

在這里插入圖片描述

以上就是MySQL數(shù)據(jù)庫(kù)事務(wù)transaction示例講解教程的詳細(xì)內(nèi)容,更多關(guān)于MySQL數(shù)據(jù)庫(kù)事務(wù)transaction的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 一文帶你了解MySQL中的子查詢(xún)

    一文帶你了解MySQL中的子查詢(xún)

    子查詢(xún)指一個(gè)查詢(xún)語(yǔ)句嵌套在另一個(gè)查詢(xún)語(yǔ)句內(nèi)部的查詢(xún),這個(gè)特性從MySQL 4.1開(kāi)始引入,SQL中子查詢(xún)的使用大大增強(qiáng)了SELECT 查詢(xún)的能力,本文帶大家詳細(xì)了解MySQL中的子查詢(xún),需要的朋友可以參考下
    2023-06-06
  • MySQL用truncate命令快速清空一個(gè)數(shù)據(jù)庫(kù)中的所有表

    MySQL用truncate命令快速清空一個(gè)數(shù)據(jù)庫(kù)中的所有表

    這篇文章主要介紹了MySQL用truncate命令快速清空一個(gè)數(shù)據(jù)庫(kù)中的所有表,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • MySQL如何實(shí)現(xiàn)負(fù)載均衡功能

    MySQL如何實(shí)現(xiàn)負(fù)載均衡功能

    這篇文章主要介紹了MySQL如何實(shí)現(xiàn)負(fù)載均衡功能,學(xué)習(xí)過(guò)數(shù)據(jù)庫(kù)的朋友們都會(huì)知道MySQL,那么如何在MySQL下實(shí)現(xiàn)負(fù)載均衡功能呢?本文就將為大家細(xì)致地介紹一下
    2019-06-06
  • MySQL redo死鎖問(wèn)題排查及解決過(guò)程分析

    MySQL redo死鎖問(wèn)題排查及解決過(guò)程分析

    被告知在多實(shí)例場(chǎng)景下 MySQL Server hang 住,無(wú)法測(cè)試下去,原生版本不存在這個(gè)問(wèn)題,而新版本上出現(xiàn)了這個(gè)問(wèn)題,不禁心頭一顫,心中不禁感到奇怪,還好現(xiàn)場(chǎng)環(huán)境還在,為排查問(wèn)題提供了一個(gè)好的環(huán)境,隨即便投入到緊張的問(wèn)題排查過(guò)程當(dāng)中
    2016-10-10
  • 登錄MySQL數(shù)據(jù)庫(kù)最快幾步(圖文步驟詳解)

    登錄MySQL數(shù)據(jù)庫(kù)最快幾步(圖文步驟詳解)

    當(dāng)?MySQL?服務(wù)開(kāi)啟后,就可以通過(guò)客戶(hù)端來(lái)登錄?MySQL?數(shù)據(jù)庫(kù)了。在?Windows?操作系統(tǒng)下可以使用?DOS?命令登錄數(shù)據(jù)庫(kù),本節(jié)將介紹使用命令方式登錄?MySQL?數(shù)據(jù)庫(kù)的方法
    2023-10-10
  • MySQL DBA 常用手冊(cè)小結(jié)

    MySQL DBA 常用手冊(cè)小結(jié)

    MySQL DBA 常用手冊(cè)小結(jié),使用mysql的朋友可以參考下。
    2011-11-11
  • Mysql、Oracle中常用的多表修改語(yǔ)句總結(jié)

    Mysql、Oracle中常用的多表修改語(yǔ)句總結(jié)

    這篇文章主要給大家介紹了關(guān)于Mysql、Oracle中常用的多表修改語(yǔ)句的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 關(guān)于mysql主備切換canal出現(xiàn)的問(wèn)題解決

    關(guān)于mysql主備切換canal出現(xiàn)的問(wèn)題解決

    這篇文章主要給大家介紹了關(guān)于mysql主備切換canal出現(xiàn)的一些問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Mysql中 show table status 獲取表信息的方法

    Mysql中 show table status 獲取表信息的方法

    這篇文章主要介紹了Mysql中 show table status 獲取表信息的方法的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • 阿里云 Centos7.3安裝mysql5.7.18 rpm安裝教程

    阿里云 Centos7.3安裝mysql5.7.18 rpm安裝教程

    這篇文章主要介紹了阿里云 Centos7.3安裝mysql5.7.18 rpm安裝教程,需要的朋友可以參考下
    2017-06-06

最新評(píng)論