MySQL高級-事務-并發事務演示及隔離級別

文章目錄

  • 0、四種隔離級別
  • 1、創建表 account
  • 2、修改當前會話隔離級別為 read uncommitted
    • 2.1、會出現臟讀
  • 3、修改當前會話隔離級別為 read committed
    • 3.1、可以解決臟讀
    • 3.2、會出現不可重復讀
  • 4、修改當前會話隔離級別為 repeatable read(默認)
    • 4.1、解決不可重復讀
    • 4.2、會出現幻讀
  • 5、修改當前會話隔離級別為 serializable
    • 5.1、可以解決幻讀

0、四種隔離級別

在這里插入圖片描述
在這里插入圖片描述

1、創建表 account

drop table if exists account;
create table account(
id int primary key AUTO_INCREMENT comment 'ID',
name varchar(10) comment '姓名',
money double(10,2) comment '余額'
) comment '賬戶表';
insert into account(name, money) VALUES ('張三',2000), ('李四',2000);

2、修改當前會話隔離級別為 read uncommitted

mysql> select @@transaction_isolation;
+-------------------------+
| @@transaction_isolation |
+-------------------------+
| REPEATABLE-READ         |
+-------------------------+
1 row in set (0.00 sec)mysql> set session transaction isolation level read uncommitted;
Query OK, 0 rows affected (0.00 sec)mysql> select @@transaction_isolation;
+-------------------------+
| @@transaction_isolation |
+-------------------------+
| READ-UNCOMMITTED        |
+-------------------------+
1 row in set (0.00 sec)mysql> 

2.1、會出現臟讀

一個事務讀到另外一個事務還沒有提交的數據。
在這里插入圖片描述>如果要解決臟讀可以把隔離級別修改為 read committed

3、修改當前會話隔離級別為 read committed

3.1、可以解決臟讀

在這里插入圖片描述

3.2、會出現不可重復讀

一個事務先后讀取同一條記錄,但兩次讀取的數據不同,稱之為不可重復讀
在這里插入圖片描述

4、修改當前會話隔離級別為 repeatable read(默認)

4.1、解決不可重復讀

在這里插入圖片描述

4.2、會出現幻讀

一個事務按照條件查詢數據時,沒有對應的數據行,但是在插入數據時,又發現這行數據已經存在,好像出現了幻影

在這里插入圖片描述
在這里插入圖片描述

5、修改當前會話隔離級別為 serializable

mysql> set session transaction isolation level serializable;
Query OK, 0 rows affected (0.00 sec)mysql> select @@transaction_isolation;
+-------------------------+
| @@transaction_isolation |
+-------------------------+
| SERIALIZABLE            |
+-------------------------+
1 row in set (0.00 sec)mysql> 

5.1、可以解決幻讀

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/37139.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/37139.shtml
英文地址,請注明出處:http://en.pswp.cn/web/37139.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

解決docker鏡像pull失敗的有效

機器環境 本實踐將在 Ubuntu 22.04.3LTS 系統上進行測試 docker 版本Docker Engine - Community 24.0.6 ,原則上docker版本無影響 本實踐進僅學習研究使用,無作他用途。 背景 曾幾何時,docker鏡像的拉去會失敗,網速會慢&#xff0…

代碼隨想錄算法訓練營第五十三天| 739. 每日溫度、 496.下一個更大元素 I、503.下一個更大元素II

LeetCode 739. 每日溫度 題目鏈接:https://leetcode.cn/problems/daily-temperatures/description/ 文章鏈接:https://programmercarl.com/0739.%E6%AF%8F%E6%97%A5%E6%B8%A9%E5%BA%A6.html 思路 * 單調棧的本質是空間換時間,因為在遍歷的過…

【論文閱讀】transformer及其變體

寫在前面: transformer模型已經是老生常談的一個東西,以transformer為基礎出現了很多變體和文章,Informer、autoformer、itransformer等等都是頂刊頂會。一提到transformer自然就是注意力機制,變體更是數不勝數,一提到…

【目標檢測】DN-DETR

一、引言 論文: DN-DETR: Accelerate DETR Training by Introducing Query DeNoising 作者: IDEA 代碼: DN-DETR 注意: 該算法是在DAB-DETR基礎上的改進,在學習該算法前,建議掌握DETR、DAB-DETR等相關知識…

TCP和UDP的區別以及應用場景

TCP(傳輸控制協議)和UDP(用戶數據報協議)是兩種不同的傳輸層協議 區別 TCP是面向連接的,UDP是無連接的; TCP是可靠的,UDP是不可靠的; TCP是面向字節流的,UDP是面向數據…

如何高效配置與使用Pip換源

目錄 1. Pip源的基本概念 1.1 常見的國內鏡像源 2. 臨時換源 2.1 使用命令行參數指定鏡像源 2.2 安裝多個包時指定鏡像源 3. 永久換源 3.1 修改用戶級配置文件 3.1.1 創建和編輯配置文件 3.2 修改全局配置文件 3.2.1 創建和編輯全局配置文件 4. 驗證換源配置 5. 切…

VMamba: Visual State Space Model論文筆記

文章目錄 VMamba: Visual State Space Model摘要引言相關工作Preliminaries方法網絡結構2D-Selective-Scan for Vision Data(SS2D) VMamba: Visual State Space Model 論文地址: https://arxiv.org/abs/2401.10166 代碼地址: https://github.com/MzeroMiko/VMamba 摘要 卷積神…

防火墻共性檢測技術

防火墻共性檢測技術 防火墻共性檢測技術是指防火墻在監控和控制網絡流量時,共同采用的一些檢測和過濾方法。無論是哪種類型的防火墻,這些技術都可以用于識別和阻止惡意流量,確保網絡安全。以下是防火墻共性檢測技術的詳細介紹,包…

axios的基本使用和vue腳手架自帶的跨域問題解決

axios的基本使用和vue腳手架自帶的跨域問題解決 1. axios 1.1 導入axios npm i axios1.2 創建serve1.js serve1.js const express require(express) const app express()app.use((request,response,next)>{console.log(有人請求服務器1了);console.log(請求來自于,re…

go Channel 原理 (一)

Channel 設計原理 不要通過共享內存的方式進行通信,而是應該通過通信的方式共享內存。 在主流編程語言中,多個線程傳遞數據的方式一般都是共享內存。 Go 可以使用共享內存加互斥鎖進行通信,同時也提供了一種不同的并發模型,即通…

npm ci vs npm i

npm ci vs npm i 幾個關鍵區別:該選擇哪個? 通過 npm ci 和 npm i 兩個命令,都可安裝項目的依賴。那么這兩個命令有什么區別呢? 幾個關鍵區別: 目的和用途: npm ci :根據項目中的 package-lock…

AI奏響未來樂章:音樂界的革命性變革

AI在創造還是毀掉音樂 引言 隨著科技的飛速發展,人工智能(AI)正在逐漸滲透到我們生活的每一個角落,音樂領域也不例外。AI技術的引入,不僅為音樂創作、教育、體驗帶來了革命性的變革,更為整個音樂產業注入了…

順序表應用——通訊錄

在本篇之前的順序表專題我們已經學習的順序表的實現,了解了如何實現順序表的插入和刪除等功能,那么在本篇當中就要學習基于順序表來實現通訊錄,在通訊錄當中能實現聯系人的增、刪、查改等功能,接下來就讓我們一起來實現通訊錄吧&a…

grpc學習golang版( 五、多proto文件示例 )

系列文章目錄 第一章 grpc基本概念與安裝 第二章 grpc入門示例 第三章 proto文件數據類型 第四章 多服務示例 第五章 多proto文件示例 第六章 服務器流式傳輸 第七章 客戶端流式傳輸 第八章 雙向流示例 文章目錄 一、前言二、定義proto文件2.1 公共proto文件2.2 語音喚醒proto文…

解決Vue3項目中跨域問題的步驟

決Vue3項目中跨域問題的步驟可以按照以下方式清晰地分點表示和歸納: 1. 使用代理服務器(Proxy) 步驟: 在Vue項目的根目錄下找到或創建vue.config.js文件。在vue.config.js中配置devServer的proxy選項。設定需要代理的接口前綴&a…

基于局域網下的服務器連接、文件傳輸以及內網穿透教程 | 服務器連接ssh | 服務器文件傳輸scp | 內網穿透frp | 研究生入學必備 | 深度學習必備

🙋大家好!我是毛毛張! 🌈個人首頁: 神馬都會億點點的毛毛張 📌本篇博客分享的是基于局域網下的服務器連接🔗、文件傳輸以及內網穿透教程,內容非常完備?,涵蓋了在服務器上做深度學…

樹莓派3B讀寫EEPROM芯片AT24C256

AT24C256是一個Atmel公司的EEPROM存儲芯片,容量是256K個bit(也就是32K字節),I2C接口,而樹莓派正好有I2C接口,如下圖藍框中的4個IO口, 把AT24C256和這4個口接在一起,這樣硬件就準備好…

Django 頁面展示模型創建表的數據

1,添加視圖函數 Test/app8/urls.py from django.shortcuts import render from .models import Userdef create_user(request):if request.method POST:username request.POST.get(username)email request.POST.get(email)# ... 獲取其他字段的值# 創建用戶實例…

【Python學習篇】Python實驗小練習——異常處理(十三)

個人名片: 🎓作者簡介:嵌入式領域優質創作者🌐個人主頁:妄北y 📞個人QQ:2061314755 💌個人郵箱:[mailto:2061314755qq.com] 📱個人微信:Vir2025WB…

【教程】5分鐘直接了解隨機森林模型

本文來自《老餅講解-BP神經網絡》https://www.bbbdata.com/ 目錄 一、什么是隨機森林模型1.1.隨機森林模型介紹1.2.為什么隨機森林要用多棵決策樹 二、怎么訓練一個隨機森林模型2.1.訓練一個隨機森林模型 隨機森林模型是機器學習中常用的模型之一,它是決策樹模型的一…