MySQL笔记——事务

事务

    • **控制事务**
    • **并发事务问题**
    • 事务隔离级别

学习黑马MySQL课程,记录笔记,用于复习。

控制事务

方式一:

#查看和设置事务提交方式
select @@autocommit ;
set @@autocommit = 0 ;
#提交事务
commmit;
#回滚事务
rollback;

方式二:

#查看和设置事务提交方式
start transaction;
#提交事务
commmit;
#回滚事务
rollback;

事物的四大特性(ACID)

  • 原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功,要么全部失败。
  • 一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。
  • 隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。
  • 持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。

并发事务问题

问题描述
赃读一个事务读到另外一个事务还没有提交的数据
不可重复读一个事务先后读取同一条记录,但两次读取的数据不同
幻读一个事务按照条件查询数据时,没有对应的数据行,但是在插入数据时,
又发现这行数据已经存在,好像出现了 “幻影”

解决不可重复读是指:在我们默认已经解决了不可重复读的问题之后,事务A的第一步和第三步查询的结果为一致的(即都为空),查询都为空但是插不进去数据,就好像有个“幻影”这种现象叫幻读

事务隔离级别

隔离级别脏读不可重复读幻读
Read uncommitted
Read committed×
Repeatable Read(默认)××
Serializable×××

查看事务隔离级别

select @@TR

设置事务隔离级别

set [ session | global ] transaction isolation level [ read uncommitted |read committed | repeatable read| serializable]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/31580.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

electron自定义标题栏的最大化,最小化,关闭窗口

渲染组件代码&#xff1a; <template><div class"window-btn"><i class"minimize" click"minimize"><img src"../assets/img/最小化.svg" alt"最小化" /></i><i v-if"!isMaximized&…

react 0至1 案例

/*** 导航 Tab 的渲染和操作** 1. 渲染导航 Tab 和高亮* 2. 评论列表排序* 最热 > 喜欢数量降序* 最新 > 创建时间降序* 1.点击记录当前type* 2.通过记录type和当前list中的type 匹配*/ import ./App.scss import avatar from ./images/bozai.png import {useState} …

【408考点之数据结构】队列:定义、特点、基本操作与应用

队列&#xff1a;定义、特点、基本操作与应用 队列的定义 队列&#xff08;Queue&#xff09;是一种特殊的线性表&#xff0c;仅允许在一端进行插入操作&#xff08;称为队尾&#xff0c;Rear&#xff09;&#xff0c;在另一端进行删除操作&#xff08;称为队头&#xff0c;F…

Springboot开发之 Excel 处理工具(二)-- Easyexcel

一、Easyexcel 简介 EasyExcel是一个基于Java的Excel处理工具库&#xff0c;它的核心设计理念是快速、简洁&#xff0c;并且能够有效解决处理大文件时的内存溢出问题。使用EasyExcel&#xff0c;开发者可以在几乎不需要考虑性能和内存消耗的情况下&#xff0c;轻松实现Excel文…

第六节 LLava模型数据处理源码解读(input_ids/labels/attention_mask/image,下篇)

文章目录 前言一、数据格式标签二、LazySupervisedDataset的__gettitem__函数源码解读1、source获取2、图像数据处理1、对话内容source获取(存在图像条件)2、对话内容source获取(不存在图像条件)3、对话文本数据加工4、data_dict进一加工5、data_dict的image元素添加6、返回…

肾虚学习实验第T1周:实现mnist手写数字识别

>- **&#x1f368; 本文为[&#x1f517;365天深度学习训练营](https://mp.weixin.qq.com/s/0dvHCaOoFnW8SCp3JpzKxg) 中的学习记录博客** >- **&#x1f356; 原作者&#xff1a;[K同学啊](https://mtyjkh.blog.csdn.net/)** 目录 一、前言 作为一名研究牲&#xff0…

全面讲解,使用Python搭建自己的后端服务(FastAPI),并提供API接口

全面讲解,使用Python搭建自己的后端服务(FastAPI),并提供API接口 开始工作推荐的项目结构详细步骤配置 Uvicorn 以在 `0.0.0.0` 上运行配置日志记录查看日志完整的项目结构其它解释为什么要对 `start.sh` 赋予执行权限背景为什么要创建 `start.sh` 脚本?为什么要对 `start…

树和二叉树的定义

目录 一、树的定义 1.1概念 1.2表示方式 1.3基本术语 1.4树结构和线性结构的比较 二、二叉树的定义 2.1概念 2.2二叉树的5种基本形态 三、二叉树的性质和存储结构 3.1二叉树的性质 3.1.1满二叉树 3.1.2完全二叉树 3.2二叉树的存储结构 3.2.1二叉树的顺序存储 3.2.…

在Ubuntu上解决 “qmake: could not find a Qt installation of ‘‘” 错误

在Ubuntu上运行qmake命令生成Makefile时&#xff0c;遇到了以下错误&#xff1a; qmake: could not find a Qt installation of 即使我安装了以下软件包&#xff0c;也未能解决此问题&#xff1a; sudo apt-get install qt4-qmake sudo apt-get install qt5-qmake如果你也遇到…

海量数据处理——bitMap/BloomFilter、hash + 统计 + 堆/归并/快排

前言&#xff1a;海量数据处理是面试中一道常考的问题&#xff0c; 生活中也容易遇到这种问题。 通常就是有一个大文件&#xff0c; 让我们对这个文件进行一系列操作——找出现次数最多的数据、求交集、是否重复出现等等。 因为文件的内容太多&#xff0c; 我们的内存通常是放不…

目标跟踪算法(bytetrack)-tensorrt部署教程

一、本机安装python环境 conda create -n bytetrace_env python=3.8 activate bytetrace_env conda install pytorch torchvision cudatoolkit=10.1 -c检测GPU是否可用,不可用不行 import torch print(torch.cuda.is_available())安装bytetrack git clone https://github.c…

计算机专业的发展前景与选择建议。

身份角度一&#xff1a;一名曾经的计算机专业学生  在我当年选择计算机专业的时候&#xff0c;计算机科学与技术、人工智能、网络安全、软件工程等专业确实是炙手可热的热门选择。然而&#xff0c;随着时间的推移&#xff0c;市场竞争加剧和市场饱和度提高&#xff0c;这些专…

ELK Kibana搜索框模糊搜索包含不包含

默认是KQL,点击切换Lucene搜索&#xff0c;搜索日志中包含Exception关键字&#xff0c;不包含BizException、IllegalArgumentException、DATA_SYNC_EXCEPTION关键字的日志&#xff0c;如下&#xff1a; message: *Exception AND !(message : *BizException OR message : *Ille…

数据库复习——模式分解

模式分解这边主要包括无损分解和保持函数依赖的分解两种形式&#xff0c;简单整理一下。 无损分解 把一个 R R R 分成 ρ { R 1 , R 2 , ⋯ , R k } \rho \{R_1,R_2,\cdots,R_k\} ρ{R1​,R2​,⋯,Rk​}&#xff0c;然后通过自然连接 R 1 ⋈ R 2 ⋈ ⋯ ⋈ R k R_1\bowtie R…

容器之布局容器的演示

代码; #include <gtk-2.0/gtk/gtk.h> #include <glib-2.0/glib.h> #include <gtk-2.0/gdk/gdkkeysyms.h> #include <stdio.h>void change_image(GtkFileChooserButton *filebutton, // GdkEvent *event,GtkImage *image) {gtk_image_set_from_file(im…

鸿蒙开发通信与连接:【@ohos.wifiext (WLAN)】

WLAN 说明&#xff1a; 本模块首批接口从API version 8开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 该文档中的接口只供非通用类型产品使用&#xff0c;如路由器等&#xff0c;对于常规类型产品&#xff0c;不应该使用这些接口。 导入模块 …

手写方法实现整型例如:123与字符串例如:“123“相互转化(下篇)

目录 一、前言 二、整型转化为字符串 1. 初始化变量 2.数字1转字符1 3.取出value中的每一项数字 4.将字符放入字符数组中 5.最终代码 三、最后 一、前言 本篇文章紧跟上篇文章&#xff0c;本片内容为整型转化为字符串类型。至于我为什么要分两篇文章&#xff0c;主要…

艺术创作加速器:三款AI绘画软件,让你的工作效率倍增!

在数字化浪潮的推动下&#xff0c;艺术创作正迎来革命性的变化。AI绘画软件的出现&#xff0c;不仅为艺术家提供了全新的创作工具&#xff0c;也为艺术爱好者开辟了一片创意的新天地。这些软件利用人工智能技术&#xff0c;根据用户的简单描述或草图&#xff0c;快速生成独特的…

Linux基础知识笔记

1.配置VNC linux&#xff1a; yum install tigervnc-server vncpasswd vncserver & New ‘2SCOM-RH72-1:1 (root)’ desktop is 2SCOM-RH72-1:1 windows: 软件: VNC-Viewer-6.20.113-Windows-64bit 连接信息 192.168.1.1:1 2.重置root密码 第一步: 开机后再内核上敲击e 第…

视频汇聚安防综合管理系统EasyCVR平台GB28181设备注册未上线的原因排查与解决

视频汇聚安防综合管理平台EasyCVR视频监控系统基于云边端架构&#xff0c;可支持海量视频汇聚集中管理&#xff0c;能提供视频监控直播、云端录像、云存储、录像检索与回看、告警&#xff08;协议告警/智能告警/1400视图库告警&#xff09;、平台级联、AI智能分析接入等视频能力…