14、mysql中事务的应用

是什么

事务是一种保护连续操作同时满足(实现)的一种机制,用来保护数据的完整性,只适用于数据操作,不适用于结构操作,只有

innodb引擎的表具有事务安全的机制。就是说,在一个事务中做一系列的sql操作,当且仅当一系列sql都执行成功时,才会对数据

库的数据进行对应的持久化

事务的特性

事务有四大特性:ACID

A:atomic原子性,事务的整个操作是一个整体,不可分割,要么全部成功,要么全部失败
C:consistency一致性,事务操作前后,数据表中的数据没有变化
I:isolation隔离性,事务操作是互相隔离不受影响的
D:durability持久性,数据一旦提交,不可改变,永久的改变数据表数据

事务的分类

事务可分为自动事务和手动事务,mysql中默认是自动事务

事务通过autocommit变量控制,当autocommit = off/0 时表示手动事务,下边介绍一下查看自动事务是否开启和开启事务

操作查看事务
sqlshow variables like 'autocommit';
结果
操作开启或关闭事务
sql

set autocommit = 0;

set autocommit = 1;

结果

事务的操作

# 使用事务
-- 开启事务(系统将将要进行的操作不直接写入到数据表,而是现存在事务日志)
start transaction;-- 执行对应的sql
update user set name = 'chaizepeng111' where id=5;
update card set card_number = '111111111' where id = 4;-- 提交或者回滚
commit;# 回滚点的设置
savepoint 回滚点名字;
savepoint a;-- 回滚到指定的回滚点
rollback to a;

事务的原理

事务的实现借助的是一个临时的日志文件,当开始事务时,发送的sql会存储到日志文件中,存储到日志文件时执行sql,将结果

存储到日志文件,当查询时,会将返回的结果经过日志文件加工后再返回,当commit时,临时文件中的结果就会同步到数据库

中,而如果rollback时,则会删除临时文件,不做任何操作

事务的隔离级别

在并发环境下使用事务时,就可能产生问题,问题大致分为3类,如下:

脏读事务A读到了事务B还未提交的数据
不可重复读在一个事务里面读取了两次某个数据,读出来的数据不一致
幻读在一个事务里面的操作中发现了未被操作的数据

为了解决以上问题,就出现了事务的隔离级别

DEFAULT默认隔离级别
READ_UNCOMMITTED读未提交,即能够读取到没有被提交的数据,一般不用
READ_COMMITED读已提交,即能够读到那些已经提交的数据,可防止脏读,一般使用此隔离级别
REPEATABLE_READ重复读取,即在数据读出来之后加锁,读取数据之后自动加锁,当前事务为结束之前,其他事务不可访问,解决了脏读、不可重复读的问题
SERLALIZABLE串行化,最高的事务隔离级别,一个事务一个事务挨着执行,效率低,不用

介绍一下mysql下如何查看和设置事务的隔离级别

解释查看事务的隔离级别
sqlselect @@tx_isolation;
结果
解释设置当前会话的事务隔离级别
sqlSET SESSION TRANSACTION ISOLATION LEVEL Read committed;
结果
解释设置全局的事务隔离级别
sqlSET GLOBALTRANSACTION ISOLATION LEVEL Read committed;
结果

补充:事务的隔离级别设置时的可选参数:Read uncommitted 、Read committed 、Repeatable read 、Serializable

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

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

相关文章

P3193-[HNOI2008]GT考试【KMP,dp,矩阵乘法】

正题 题目链接:https://www.luogu.com.cn/problem/P3193 题目大意 求有多少个长度为nnn的字符串不包含子串sss。 解题思路 考虑dpdpdp,用fi,jf_{i,j}fi,j​表示第iii个已经匹配到jjj时的方案数。 显然这与正常匹配十分相似,我们分为两种情况 ansi1sj…

Summer Training day4 欧拉降幂

Input2 Output2Hint 1. For N 2, S(1) S(2) 1.2. The input file consists of multiple test cases. Sample Input2 Sample Output2这道题的公式非常简单,就是求2^(N-1) %1e97 由于N实在是太大了,不能直接求快速幂,考虑到2^x % MOD是有循…

Project Honolulu 正式版发布为 Windows Admin Center

微软今天正式发布了 Project Honolulu 的正式版,其正式的名称为 Windows Admin Center,gOxiA 之前一直在这个 TAP 中,从 1711 到 1804 可以看出微软现在的开发速度之快,从测试情况看 WAC 质量非常高。正如之前日志说讲 Windows Ad…

15、sql编程基本语法介绍

使用sql也可以像java一样进行程序编写,说到编程,就离不开变量和流程控制,接下来介绍一下 变量 sql中的变量可分为系统变量和自定义变量 系统变量用于控制服务器表现的变量查看所有系统变量show global variables [like %关键字%]; -- 查看…

使用C# (.NET Core) 实现命令设计模式 (Command Pattern)

本文的概念内容来自深入浅出设计模式一书.项目需求有这样一个可编程的新型遥控器, 它有7个可编程插槽, 每个插槽可连接不同的家用电器设备. 每个插槽对应两个按钮: 开, 关(ON, OFF). 此外还有一个全局的取消按钮(UNDO).现在客户想使用这个遥控器来控制不同厂家的家用电器, 例如…

P4170-[CQOI2007]涂色【区间dp】

正题 题目链接:https://www.luogu.com.cn/problem/P4170 题目大意 给出长度为nnn的串目标串,每次可以在一连续的区间覆盖同种字符,求最少覆盖次数。 解题思路 我们分情况考虑,用fi,jf_{i,j}fi,j​表示从i∼ji\sim ji∼j都涂好需要的最少次…

16、mysql中函数的创建和使用

sql语言可以进行编程,说到编程,那一定少不了使用函数对代码进行最小级别的封装,接下来介绍一下mysql中函数的写法以及应用 mysql中的函数可分为两类:系统函数、用户自定义函数。 简单的介绍几个常用的系统的函数: 函…

Summer Training day4上帝与集合的正确用法 欧拉函数+降幂公式

这个题的指数太大了&#xff0c;因此要考虑用降幂公式进行降幂 记f(p) 2^2^2... % p f(p) 2^(2^2^2...%phi(p) phi(p)) % p 2^(f(phi(p)) phi(p)) % p 到这里我们得到了一个递推方程&#xff0c;边界f(1) 0 #include <iostream> #include <cstdio> #inclu…

17、mysql中的存储过程的应用

其实存储过程也可以叫做过程&#xff0c;而函数也可以叫做存储函数&#xff0c;两者都是处理数据的一种方式&#xff0c;但是不同在于函数是必须要有返回值的&#xff0c;而过程则没有返回值&#xff0c;过程可以理解为是一种用来处理数据的没有返回值的函数&#xff0c;但是他…

CF9D-How many trees?【dp】

正题 题目链接:https://www.luogu.com.cn/problem/CF9D 题目大意 求nnn个点组成的深度大于hhh的二叉树有多少个。 解题思路 定义fi,jf_{i,j}fi,j​表示iii个点高度为jjj的树有多少个&#xff0c;然后每次将两棵(a,b)(x,y)(a,b)(x,y)(a,b)(x,y)合并就有 fax1,max{b,y}1fa,b∗…

把旧系统迁移到.Net Core 2.0 日记(2) - 依赖注入/日志NLog

Net Core 大量使用依赖注入(Dependency Inject), 打个比方,我们常用的日志组件有Log4Net,NLog等等.如果我们要随时替换日志组件,那么代码中就不能直接引用某个组件的内容,也不能直接New 某个组件.而是应该定义一组接口, 然后包装各个组件,实现这个接口. Net Core 自带组件容器,…

18、数据的备份和还原

mysql中数据的备份有以下几种方式&#xff1a; 1、直接在数据库文件夹中复制对应的表结构以及数据文件进行数据备份 2、将每一张表中的数据进行备份 3、使用mysqldump.exe 进行备份 4、增量数据备份 接下来就详细的介绍一下每一种备份的具体操作 直接在数据库文件夹中复制…

开源纯C#工控网关+组态软件(九)定制Visual Studio

一、 引子因为最近很忙&#xff08;lan&#xff09;&#xff0c;很久没发博了。不少朋友对那个右键弹出菜单和连线的功能很感兴趣&#xff0c;因为VS本身是不包含这种功能的。大家想这是什么鬼&#xff0c;怎么我的设计器没有&#xff0c;其实这是一个微软黑科技&#xff0c;…

P2805-[NOI2009]植物大战僵尸【网络流,最大权闭合图】

正题 题目链接:https://www.luogu.com.cn/problem/P2805 题目大意 n∗mn*mn∗m的格子&#xff0c;攻击这个格子(x,y)(x,y)(x,y)可以获得价值cx,yc_{x,y}cx,y​&#xff0c;攻击一个格子(x,y)(x,y)(x,y)前要攻击(x,y1)(x,y1)(x,y1)。 对于有的格子(x,y)(x,y)(x,y)会保护些格子…

19、mysql中定时器的创建和使用

mysql中可以使用定时器&#xff0c;用来进行计划的调度&#xff0c;在mysql中定时器通过事件的形式存在&#xff0c;接下来介绍一下定时器的使用 创建定时器 CREATE EVENT IF NOT EXISTS 计划名-- 计划频率和开启计划时间或者是计划执行的时间-- 前一个可以实现持续的计划调度…

使用C#实现适配器模式 (Adapter Pattern) 和外观模式 (Facade Pattern)

本文的概念内容来自深入浅出设计模式一书现实世界中的适配器(模式)我带着一个国标插头的笔记本电脑, 来到欧洲, 想插入到欧洲标准的墙壁插座里面, 就需要用中间这个电源适配器.面向对象的适配器你有个老系统, 现在来了个新供应商的类, 但是它们的接口不同, 如何使用这个新供应商…

jzoj3852-单词接龙【0/1分数规划,负环】

正题 题目链接:https://jzoj.net/senior/#main/show/3852 题目大意 nnn个单词串&#xff0c;头尾有两个相同单词就可以连在一起&#xff0c;求一个最长的环使得平均单词长度最长。 解题思路 其实总共26∗2626*2626∗26个点&#xff0c;然后求一个回路使得平均边长最长 就是0…

20、mysql中触发器的使用

是什么 触发器不同于定时器&#xff0c;触发器用在表中的记录上&#xff0c;每当表中的记录进行增、删、改操作时&#xff0c;则绑定在表上的对应的触发器被触发&#xff0c;进行对应的操作。&#xff08;有点类似于java中的swing中的监听器&#xff09; 怎么用 可以表中每一…

在 .NET Core 中使用 DiagnosticSource 记录跟踪信息

前言最新一直在忙着项目上的事情&#xff0c;很久没有写博客了&#xff0c;在这里对关注我的粉丝们说声抱歉&#xff0c;后面我可能更多的分享我们在微服务落地的过程中的一些经验。那么今天给大家讲一下在 .NET Core 2 中引入的全新 DiagnosticSource 事件机制&#xff0c;为什…

jzoj3854-分组【树状数组,线段树】

正题 题目链接:https://jzoj.net/senior/#contest/show/2990/2 题目大意 一个小队满足要求 队长的地位最高所有队员和队长的年龄差不超过kkk 给出nnn个人的地位和年龄&#xff0c;qqq个询问 每次询问一组(x,y)(x,y)(x,y)求若(x,y)(x,y)(x,y)在同一个队里那这个队的最多人数…