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

Mysql中的select ...for update

 更新時(shí)間:2023年08月29日 11:01:18   作者:哇~是小菜呀  
這篇文章主要介紹了Mysql中的select ...for update用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Mysql select ...for update

這幾天遇到了select … for update的sql語(yǔ)句,決定整理一下mysql的兩種鎖機(jī)制。

Mysql數(shù)據(jù)庫(kù)有兩種鎖,一種是共享鎖,一種是排他鎖,這兩種鎖是針對(duì)InnoDB的,如果是MyISM不是這樣的鎖機(jī)制。

共享鎖和拍他鎖的鎖對(duì)象是主鍵!

共享鎖(讀鎖,S鎖)

select … from … lock in share mode

多個(gè)事務(wù)共享一把鎖,但是只能讀,不能修改。

當(dāng)有事務(wù)拿到共享鎖的時(shí)候且鎖未釋放時(shí),另一個(gè)事務(wù)不能去修改加鎖的數(shù)據(jù)。

在這里插入圖片描述

共享鎖的最大特點(diǎn)是可以共享,多個(gè)事務(wù)可以同時(shí)獲取鎖并且讀到數(shù)據(jù),并且,在鎖沒(méi)有釋放時(shí),數(shù)據(jù)不能被修改,這樣可以避免數(shù)據(jù)庫(kù)臟讀和不可重復(fù)讀的問(wèn)題。

排他鎖(互斥鎖,寫(xiě)鎖,X鎖)

select … for update;

排他鎖 不能被多個(gè)事務(wù)共享,如果一個(gè)事務(wù)獲取了一行數(shù)據(jù)的排他鎖,那么其他事務(wù)就不能獲取這行數(shù)據(jù)的鎖,包括共享鎖和排他鎖。

獲取到排他鎖的事務(wù)可以對(duì)數(shù)據(jù)進(jìn)行讀取和修改,事務(wù)提交后,鎖釋放。

在這里插入圖片描述

演示

創(chuàng)建一張用于測(cè)試的表格

CREATE TABLE `emipe_user_entity` (
  `id` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '主鍵',
  `user_name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin DEFAULT NULL COMMENT '用戶(hù)名',
  `pass_word` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin DEFAULT NULL COMMENT '用戶(hù)密碼',
  `status` int(11) DEFAULT NULL COMMENT '用戶(hù)狀態(tài)',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;

使用InnoDB儲(chǔ)存引擎,InnoDB既支持行級(jí)鎖,又支持表級(jí)鎖,默認(rèn)情況下采用行級(jí)鎖

MySQL InnoDB引擎默認(rèn)的update,delete,insert語(yǔ)句會(huì)自動(dòng)給涉及到的數(shù)據(jù)加上排他鎖。

為測(cè)試的表格存入數(shù)據(jù)

INSERT INTO `emipe_user_entity` VALUES ('1', '小紅帽', '123456', 0);
INSERT INTO `emipe_user_entity` VALUES ('2', '路人甲', '523456', 0);

共享鎖

事務(wù)A:獲取共享鎖,但不提交事務(wù)

begin;
select * from emipe_user_entity where id = 1 lock in share mode;

事務(wù)B:獲取共享鎖,可以查詢(xún)到數(shù)據(jù)

select * from emipe_user_entity where id = 1 lock in share mode;

事務(wù)C:嘗試修改帶有共享鎖的數(shù)據(jù),報(bào)錯(cuò)

update emipe_user_entity set pass_word = '222222' where id = 1;

結(jié)果:

在這里插入圖片描述

事務(wù)C首先會(huì)等待共享鎖釋放,待鎖釋放后,可以對(duì)改數(shù)據(jù)進(jìn)行修改,由于事務(wù)A一直沒(méi)有釋放鎖,在長(zhǎng)久的等待后,事務(wù)C拋錯(cuò):

Lock wait timeout exceeded;try restarting trasacrtion.

等待鎖超時(shí);嘗試重啟這個(gè)事務(wù)

排他鎖

事務(wù)A:獲取排他鎖進(jìn)行查詢(xún),事務(wù)不提交

begin;
select * from emipe_user_entity where id = 1 for update;

事務(wù)B:嘗試獲取排他鎖,被阻塞

select * from emipe_user_entity where id = 1 for update;

事務(wù)C: 嘗試獲取共享鎖,被阻塞

select * from emipe_user_entity where id = 1 lock in share mode;

事務(wù)D:在不使用鎖的情況下,可以查詢(xún)數(shù)據(jù)

select * from emipe_user_entity where id = 1;
-- 查詢(xún)成功

普通的查詢(xún)語(yǔ)句沒(méi)有任何鎖機(jī)制。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別整理

    MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別整理

    這篇文章主要介紹了MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別整理,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-08-08
  • MySQL高可用與擴(kuò)展方式

    MySQL高可用與擴(kuò)展方式

    本文深入探討了MySQL的高可用和擴(kuò)展策略,包括主從復(fù)制與讀寫(xiě)分離、MySQL集群與負(fù)載均衡、分布式數(shù)據(jù)庫(kù)架構(gòu)以及數(shù)據(jù)庫(kù)的水平與垂直擴(kuò)展,每個(gè)主題都提供了詳細(xì)的代碼示例,幫助讀者理解和應(yīng)用這些技術(shù),通過(guò)這些策略,可以有效地提高M(jìn)ySQL數(shù)據(jù)庫(kù)的性能、吞吐量和可用性
    2025-03-03
  • MySql執(zhí)行流程與生命周期詳解

    MySql執(zhí)行流程與生命周期詳解

    當(dāng)你執(zhí)行一次MySQL查詢(xún)時(shí),有沒(méi)有仔細(xì)想過(guò),在查詢(xún)結(jié)果返回之前,經(jīng)過(guò)了哪些步驟呢?這些步驟有可能消耗了超出想象的時(shí)間和資源。因此,在對(duì)MySQL的查詢(xún)進(jìn)行優(yōu)化之前,應(yīng)該了解一下MySQL查詢(xún)的生命周期
    2022-09-09
  • mysql如何實(shí)現(xiàn)多行查詢(xún)結(jié)果合并成一行

    mysql如何實(shí)現(xiàn)多行查詢(xún)結(jié)果合并成一行

    利用函數(shù):group_concat(),實(shí)現(xiàn)一個(gè)ID對(duì)應(yīng)多個(gè)名稱(chēng)時(shí),原本為多行數(shù)據(jù),把名稱(chēng)合并成一行
    2013-12-12
  • 詳解grep獲取MySQL錯(cuò)誤日志信息的方法

    詳解grep獲取MySQL錯(cuò)誤日志信息的方法

    在本篇文章中小編給大家整理了關(guān)于通過(guò)grep 獲取MySQL錯(cuò)誤日志信息的方法的相關(guān)知識(shí)點(diǎn)內(nèi)容,有需要的朋友們跟著學(xué)習(xí)下。
    2018-09-09
  • MySQL修改時(shí)區(qū)的方法小結(jié)

    MySQL修改時(shí)區(qū)的方法小結(jié)

    這篇文章主要介紹了MySQL修改時(shí)區(qū)的方法,總結(jié)分析了三種常見(jiàn)的MySQL時(shí)區(qū)修改技巧,包括命令行模式、配置文件方式及代碼方式,需要的朋友可以參考下
    2016-05-05
  • 通過(guò)兩種方式增加從庫(kù)——不停止mysql服務(wù)

    通過(guò)兩種方式增加從庫(kù)——不停止mysql服務(wù)

    現(xiàn)在生產(chǎn)環(huán)境MySQL數(shù)據(jù)庫(kù)是一主一從,由于業(yè)務(wù)量訪問(wèn)不斷增大,故再增加一臺(tái)從庫(kù)。前提是不能影響線(xiàn)上業(yè)務(wù)使用,也就是說(shuō)不能重啟MySQL服務(wù),為了避免出現(xiàn)其他情況,選擇在網(wǎng)站訪問(wèn)量低峰期時(shí)間段操作
    2015-11-11
  • 一文教你學(xué)會(huì)定位線(xiàn)上MySQL鎖超時(shí)問(wèn)題

    一文教你學(xué)會(huì)定位線(xiàn)上MySQL鎖超時(shí)問(wèn)題

    這篇文章主要介紹了一文教你學(xué)會(huì)定位線(xiàn)上MySQL鎖超時(shí)問(wèn)題,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • linux下mysql自動(dòng)備份數(shù)據(jù)庫(kù)與自動(dòng)刪除臨時(shí)文件

    linux下mysql自動(dòng)備份數(shù)據(jù)庫(kù)與自動(dòng)刪除臨時(shí)文件

    mysql自動(dòng)備份數(shù)據(jù)庫(kù)與自動(dòng)刪除臨時(shí)文件,有需要的朋友可以參考下
    2013-02-02
  • 詳細(xì)介紹windows下MySQL安裝教程

    詳細(xì)介紹windows下MySQL安裝教程

    這篇文章主要給大家介紹的是windows下MySQL安裝教程,其實(shí)好多公司,數(shù)據(jù)庫(kù)的面試題都是不可避免的,甚至一些前端工程師面試的時(shí)候都避免不了被詢(xún)問(wèn)到和數(shù)據(jù)庫(kù)有關(guān)的一些問(wèn)題。下面就從最基礎(chǔ)的安裝教程開(kāi)始,需要的朋友可以參考一下
    2021-11-11

最新評(píng)論