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

MySQL系列之十 MySQL事務隔離實現(xiàn)并發(fā)控制

 更新時間:2021年07月02日 16:13:40   作者:生生不息.連綿不絕  
今天的內(nèi)容就和大家聊一聊MySQL數(shù)據(jù)庫中關于MySQL事務隔離實現(xiàn)并發(fā)控制的問題,主要是基于鎖實現(xiàn)控制技術

一、并發(fā)訪問控制

實現(xiàn)的并發(fā)訪問的控制技術是基于鎖;

鎖分為表級鎖和行級鎖,MyISAM存儲引擎不支持行級鎖;InnoDB支持表級鎖和行級鎖;

鎖的分類有讀鎖和寫鎖,讀鎖也被稱為共享鎖,加讀鎖的時候其他的人可以讀;寫鎖也稱為獨占鎖或排它鎖,一個寫鎖會阻塞其他讀操作和寫操作;

鎖還分為隱式鎖和顯式鎖,隱式鎖由存儲引擎自行管理,顯式鎖是用戶手動添加鎖;

鎖策略:在鎖粒度及數(shù)據(jù)安全性尋求的平衡機制。

顯式鎖的使用方法:LOCK TABLES tbl_name READ|WRITE

MariaDB [school]> LOCK TABLES students READ;  #加讀鎖
MariaDB [school]> UNLOCK TABLES;  #解鎖

讀鎖:任何人都不可寫

寫鎖:自己可以讀寫,但是其他人不可讀寫

FLUSH TABLES tb_name :關閉正在打開的表(清除查詢緩存),通常在備份前加全局讀鎖

SELECT clause [FOR UPDATE | LOCK IN SHARE MODE] 查詢時加寫或讀鎖

二、事務Transactions

​一組原子性的SQL語句,或一個獨立工作單元

1、事務遵循ACID原則:

  • A:atomicity原子性;整個事務中的所有操作要么全部成功執(zhí)行,要么全部失敗后回滾
  • C:consistency一致性;數(shù)據(jù)庫總是從一個一致性狀態(tài)轉(zhuǎn)換為另一個一致性狀態(tài)
  • I:Isolation隔離性;一個事務所做出的操作在提交之前,是不能為其它事務所見;隔離有多種隔離級別,實現(xiàn)并發(fā)
  • D:durability持久性;一旦事務提交,其所做的修改會永久保存于數(shù)據(jù)庫中

2、事務的生命周期

顯式事務:明確的規(guī)定事務的開始

隱式事務:默認為隱式事務,每執(zhí)行完一句語句后直接提交

autocommit = {OFF|ON} 開啟或關閉自動提交,建議使用顯式請求和提交事務,而不要使用“自動提交”功能

啟動事務:START TRANSACTION;

插入標簽:ROLLBACK TO ##;

撤銷回指定標簽:ROLLBACK TO ##;

全部撤銷:ROLLBACK;

提交事務:COMMIT;

刪除標簽:RELEASE SAVEPOINT;

MariaDB [school]> START TRANSACTION;  #明確指明啟動一個事務
MariaDB [school]> INSERT students(StuID,Name,Age,Gender) VALUES (26,'Tom',22,'M');  #添加一條記錄
MariaDB [school]> SAVEPOINT sp26;  #插入一個標簽
MariaDB [school]> INSERT students(StuID,Name,Age,Gender) VALUES (27,'Maria',12,'F');  #再加入一條記錄
MariaDB [school]> SELECT * FROM students WHERE stuid IN (26,27);  #查看一下,可以看到剛剛插入的數(shù)據(jù)
+-------+-------+-----+--------+---------+-----------+
| StuID | Name  | Age | Gender | ClassID | TeacherID |
+-------+-------+-----+--------+---------+-----------+
|    26 | Tom   |  22 | M      |    NULL |      NULL |
|    27 | Maria |  12 | F      |    NULL |      NULL |
+-------+-------+-----+--------+---------+-----------+
MariaDB [school]> ROLLBACK TO sp26;  #撤銷到sp26標簽之前的狀態(tài)
MariaDB [school]> SELECT * FROM students WHERE stuid IN (26,27);  #查看一下,剛剛maria的信息被撤回了
+-------+------+-----+--------+---------+-----------+
| StuID | Name | Age | Gender | ClassID | TeacherID |
+-------+------+-----+--------+---------+-----------+
|    26 | Tom  |  22 | M      |    NULL |      NULL |
+-------+------+-----+--------+---------+-----------+
MariaDB [school]> COMMIT;  #提交事務
MariaDB [school]> SELECT * FROM students WHERE stuid IN (26,27);  #最終的數(shù)據(jù)
+-------+------+-----+--------+---------+-----------+
| StuID | Name | Age | Gender | ClassID | TeacherID |
+-------+------+-----+--------+---------+-----------+
|    26 | Tom  |  22 | M      |    NULL |      NULL |
+-------+------+-----+--------+---------+-----------+

3、事務的隔離級別

  • READ UNCOMMITTED 其他事務可以看到未提交的臟數(shù)據(jù),產(chǎn)生臟讀
  • READ COMMITTED 提交后其他事務可以看到修改后的數(shù)據(jù),每次讀取的數(shù)據(jù)可能不一致,不可重復讀
  • REPEATABLE READ 可重復讀,每次看到的數(shù)據(jù)都一致,數(shù)據(jù)被修改后看不到最新數(shù)據(jù),會產(chǎn)生幻讀(默認設置)
  • SETIALIZABILE 未提交的讀事務阻塞修改事務,串行執(zhí)行,并發(fā)性差

MVCC: 多版本并發(fā)控制,和事務級別相關

修改事務隔離級別:服務器變量tx_isolation指定,默認為REPEATABLE-READ,可在GLOBAL和SESSION級進行設置

tx_isolation

  • Description: The transaction isolation level. See also SET TRANSACTION ISOLATION LEVEL.
  • Commandline: --transaction-isolation=name
  • Scope: Global, Session
  • Dynamic: Yes
  • Type: enumeration
  • Default Value: REPEATABLE-READ
  • Valid Values: READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE
MariaDB [school]> SELECT @@tx_isolation;   #默認為可重復讀級別
+-----------------+
| @@tx_isolation  |
+-----------------+
| REPEATABLE-READ |
+-----------------+
MariaDB [school]> SET tx_isolation='READ-UNCOMMITTED';
MariaDB [school]> set tx_isolation='READ-COMMITTED';
MariaDB [school]> set tx_isolation='REPEATABLE-READ';
MariaDB [school]> set tx_isolation='SERIALIZABLE';

4、死鎖

​兩個或多個事務在同一資源相互占用,并請求鎖定對方占用的資源的狀態(tài)會發(fā)生死鎖

在A事務修改t1表的第3行,B事務修改t2表的第2行時;這時A事務去修改t2表的第2行,這時就把A事務阻塞了,然后B事務有剛剛好去修改t1表的第3行,這時B事務也被阻塞了,這時就產(chǎn)生了死鎖。

倆個事務同時去更改對方的修改的表,互相阻塞;系統(tǒng)會發(fā)現(xiàn)死鎖,會自動犧牲一個代價小的事務來解開死鎖。

ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction

查看進程列表:MariaDB [school]> SHOW PROCESSLIST;

殺死進程:MariaDB [school]> KILL 5;

到此這篇關于MySQL系列之十 MySQL事務隔離實現(xiàn)并發(fā)控制的文章就介紹到這了,更多相關mysql并發(fā)控制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

到此這篇關于MySQL系列之十 MySQL事務隔離實現(xiàn)并發(fā)控制的文章就介紹到這了,更多相關mysql并發(fā)控制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解如何在阿里云上安裝mysql

    詳解如何在阿里云上安裝mysql

    mysql作為輕量級開源數(shù)據(jù)庫,在企業(yè)級的應用中非常的廣泛。這篇文章主要介紹了詳解如何在阿里云上安裝mysql,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • MYSQL5 masterslave數(shù)據(jù)同步配置方法

    MYSQL5 masterslave數(shù)據(jù)同步配置方法

    因線路或安全需要我們不得不考慮mysql的備份,特把mysql數(shù)據(jù)備份的方法整理下。
    2008-09-09
  • MySQL?賬號密碼錯誤終極解決方法

    MySQL?賬號密碼錯誤終極解決方法

    這篇文章主要介紹了MySQL?賬號密碼錯誤終極解決方法,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • MySQL如何快速導入數(shù)據(jù)

    MySQL如何快速導入數(shù)據(jù)

    這篇文章主要介紹了MySQL如何快速導入數(shù)據(jù),幫助大家更好的理解和學習MySQL,感興趣的朋友可以了解下
    2020-08-08
  • mysql使用GROUP BY分組實現(xiàn)取前N條記錄的方法

    mysql使用GROUP BY分組實現(xiàn)取前N條記錄的方法

    這篇文章主要介紹了mysql使用GROUP BY分組實現(xiàn)取前N條記錄的方法,結(jié)合實例形式較為詳細的分析了mysql中GROUP BY分組的相關使用技巧,需要的朋友可以參考下
    2016-06-06
  • MySQL索引事務詳細解析

    MySQL索引事務詳細解析

    這篇文章主要介紹了MySQL數(shù)據(jù)庫索引事務,索引是為了加速對表中數(shù)據(jù)行的檢索而創(chuàng)建的一種分散的存儲結(jié);事物是屬于計算機中一個很廣泛的概念,一般是指要做的或所做的事情,下面我們就一起進入文章了解具體內(nèi)容吧
    2022-01-01
  • InnoDB數(shù)據(jù)庫死鎖問題處理

    InnoDB數(shù)據(jù)庫死鎖問題處理

    本文給大家講解的是mysql數(shù)據(jù)庫InnoDB類型,在update表的時候出現(xiàn)死鎖現(xiàn)象的原因及解決辦法,有需要的小伙伴可以參考下。
    2016-03-03
  • 深入理解Mysql事務隔離級別與鎖機制問題

    深入理解Mysql事務隔離級別與鎖機制問題

    MySQL默認的事務隔離級別是可重復讀,用Spring開發(fā)程序時,如果不設置隔離級別默認用MySQL設置的隔離級別,如果Spring設置了就用已設置的隔離級別,本文重點給大家介紹Mysql事務隔離級別與鎖機制的相關知識,一起看看吧
    2021-09-09
  • MySQL 5.7并發(fā)復制隱式bug實例分析

    MySQL 5.7并發(fā)復制隱式bug實例分析

    這篇文章主要給大家介紹了關于MySQL 5.7并發(fā)復制隱式bug的相關資料,文中介紹的非常詳細,對大家學習或者使用mysql5.7具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • MySql官方手冊學習筆記1 MySql簡單上手

    MySql官方手冊學習筆記1 MySql簡單上手

    這是我學習MySql 5.1時做的一些整理與筆記,希望能理一理自己學到的東西,如果能有助于各位同道學習MySql那就更是意外之喜了,呵呵
    2012-10-10

最新評論