前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【MySql】MySql的事务基础篇

【MySql】MySql的事务基础篇

作者头像
平凡的人1
发布于 2023-10-15 04:31:54
发布于 2023-10-15 04:31:54
20600
代码可运行
举报
运行总次数:0
代码可运行

CURD加控制

模拟一个买票系统的场景如下所示:

MySQL注定会被多个客户端进行访问的,这个是肯定的,存储的都是数据,数据在上层可能有一个线程在用,另一个线程也想从数据库中获取,还有其他的客户端也想获取数据,数据被所有人共享,所以mysqld服务会有多个请求过来让我们进行数据的CURD操作,MySQL内部是采用多线程的方式实现数据的存储的相关操作,所以会有对数据的并发访问的场景。所以关系型数据库提供了事务,MySQL一般设置的更完善一些。

实际场景:

在一个卖票系统中,包含了票的id,name,以及数量nums,客户端A检查还有一张票时,把票卖掉,还没执行更新数据库时,客户端B检查了票数,发现大于0,于是又卖了一次票,然后A将票数更新会数据库,这是同一张票被卖了两次,这是不符合正常的业务逻辑的。 CURD需要满足以下属性,解决上面所出现的问题: 买票的过程得是原子的、买票应该不能互相影响、买完票应该要永久有效、买前与买后都要是确定的状态

什么是事物

事务就是一组DML语句组成,这些语句在逻辑上存在相关性,这一组DML语句要么全部成功,要么全部失败,是一个整体。MySQL提供一种机制,保证我们达到这样的效果。事务还规定不同的客户端看到的数据是不相同的

事务就是要做的或所做的事情,主要用于处理操作量大,复杂度高的数据。比如:当你毕业了,对于教务系统后台 MySQL 中,就不需要你的数据了,那么要删除你的基本信息(如姓名,电话,籍贯等等这些)的同时,也会删除和你有关的其他信息,比如:各科的成绩,在校表现,甚至你在论坛发过的文章等。这样,就需要多条 MySQL 语句构成,那么所有这些操作合起来,就构成了一个事务

对于一个MuSQL数据库,可不止一个事务在运行,同一时刻,甚至会有大量的请求被包装成事务,在向MySQL服务器发起事务处理请求时,而每条事务至少有一条SQL,最后很多条SQL,这样如果大家都访问同样的表数据,不加保护的情况下,就会出现问题。甚至可能因为事务由多条SQL构成,那么也会存在执行到一半出错或者不想在执行的情况,所以已经执行的应该这样做:

一个完整的事务,绝对不是简单的SQL集合,还要满足如下四个属性:

原子性:一个事务中的苏我又操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始 前的状态,就像这个事务从来没有执行过一样。 一致性:在事务开始之前和结束之后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。 隔离性:数据库允许多个并发事务同时对数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交(Read uncommitted),读提交、可重复度(repeatable read)和串行化(Serializable) 持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失。

上面四个属性,可以简称为 ACID 。 原子性(Atomicity,或称不可分割性) 一致性(Consistency) 隔离性(Isolation,又称独立性) 持久性(Durability)。

为什么会出现事务

事务被MySQL编写者设计出来,本质是为了当应用程序访问数据库的时候,事务能够简化我们的编程模型,不需要我们去考虑各种各样的潜在错误和并发问题,当我们使用事务时,要么提交,要么回滚,我们不会再去考虑网络异常、服务器宕机了,同时更改一个数据。 所以事务本质上是为了应用层服务的,而不是伴随着数据库系统天生就有的。

我们后面把MySQL中的一行信息,称为一行记录。

事务的版本支持

在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务, MyISAM 不支持

我们来查看一下:查看命令如下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
show engines \G

可以清楚地看到MyISAM是不支持事务的。

事务的提交方式

事务的提交方式常见的有两种:自动提交手动提交

查看事务提交方式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
show variables like 'autocommit';

用 SET 来改变 MySQL 的自动提交模式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
-- 关闭自动提交
set autocommit=0;


-- 打开自动提交
set autocommit=1;

mysql就是服务端进程,本质是网络服务,底层采用tcp协议,默认端口是3306:

对于端口号,可以把mysql的端口号改一下,不要特别常见的端口号,可以前往/etc/my.cnf文件中进行修改。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-10-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
Java Agent(一)、初步认识Instrumentation
Instrumentation 是 Java SE 5 引入的一套 API,它允许开发者在运行时修改类的字节码。Java Instrumentation 可以实现在方法插入额外的字节码从而达到收集使用中的数据到指定工具的目的。Java.lang.instrument包的最大功能就是可以在已有的类上附加(修改)字节码来实现增强的逻辑,它最常见的用途包括:
有一只柴犬
2024/12/10
2980
Java Agent(一)、初步认识Instrumentation
99%的Java程序员不知道的Java Instrument-IDEA 破解的原理
Java Instrumentation API 是一个强大的工具,它允许开发人员在运行时修改字节码,而无需重新编译或修改源代码。这对于性能监控、日志记录、安全审计等场景非常有用。本文将深入探讨Java Instrumentation的基础知识,并通过具体的代码示例来展示如何使用-javaagent选项以及premain和agentmain方法来实现一些实用的功能。
井九
2024/10/12
1350
99%的Java程序员不知道的Java Instrument-IDEA 破解的原理
谈谈Java Agent技术的实现
Java Agent本质上可以理解为一个插件,该插件就是一个精心提供的Jar包,这个Jar包通过JVMTI(JVM Tool Interface)完成加载,最终借助JPLISAgent(Java Programming Language Instrumentation Services Agent)完成对目标代码的修改。
FB客服
2022/11/14
4120
谈谈Java Agent技术的实现
JVM 字节码增强技术之 Java Agent 入门
分布式链路追踪中为了获取服务之间调用链信息,采集器通常需要在方法的前后做埋点。在 Java 生态中,常见的埋点方式有两种:
高楼Zee
2021/10/27
1.5K0
浅谈 Java Agent 内存马
https://www.yuque.com/tianxiadamutou/zcfd4v/tdvszq
亿人安全
2022/06/30
2.6K0
浅谈 Java Agent 内存马
Java代理技术解密:揭秘方法计时器的神奇实现
最近在了不起在与外部交流的时候,Java的agent技术被提起,想来自己都有些时间没有使用它了,本文简单讲讲什么是agent技术,并结合一个方法计时器的实际例子。
灬沙师弟
2023/07/08
2110
Java代理技术解密:揭秘方法计时器的神奇实现
​Java Agent原理及实现
Java Agent是Java SE 5.0版本引入的一个新特性,它可以在Java虚拟机(JVM)启动前或者在运行时动态地读取一些class文件,并在内存中修改后替换原始的class文件,从而在不改变原有代码的情况下增强或者监视应用程序的运行。
架构狂人
2023/08/16
9640
​Java Agent原理及实现
认识 JavaAgent --获取目标进程已加载的所有类
之前在一个应用中搜索到一个类,但是在反序列化测试时出错,错误不是class notfound,是其他0xxx这样的错误,通过搜索,这个错误大概是类没有被加载。最近刚好看到了JavaAgent,初步学习了下,能进行拦截,主要通过Instrument Agent来进行字节码增强,可以进行字节码插桩,bTrace,Arthas 等操作,结合ASM,javassist,cglib框架能实现更强大的功能。Java RASP也是基于JavaAgent实现的。趁热记录下JavaAgent基础概念,以及简单使用JavaAgent实现一个获取目标进程已加载的类的测试。
Seebug漏洞平台
2019/12/16
2.3K0
认识 JavaAgent --获取目标进程已加载的所有类
【Java编程进阶之路 04】深入探索:Java类加载器与双亲委派 & 打破双亲委派桎梏
在Java的世界里,类加载器(ClassLoader)是一个核心组件,它负责在运行时动态加载Java类到JVM中。为了确保Java应用的安全和稳定,Java设计者们引入了一种称为“双亲委派模型”(Parent Delegation Model)的类加载机制。这种机制不仅避免了类的重复加载,还保护了系统的安全。下面我们将详细探讨双亲委派机制的工作原理、优势、以及它在Java生态系统中的应用。
夏之以寒
2024/03/05
2400
深入理解Instrument(一)
很早之前就了解到目前主流的APM开源框架如Pinpoint、SkyWalking等等都是通过java.lang.instrument包提供的字节码增强功能来实现的。趁着对这块的热情还没消退,抽时间分析一下java.lang.instrument包的使用方式,记录下来写成一个系列的文章。本系列博文针对的是JDK11,其他版本的JDK可能不适合。
Throwable
2020/06/23
3K0
深入理解Instrument(一)
动态追踪之java agent
上篇文章我们说到阿里的诊断工具Arthas对方法和类的监控使用的是动态追踪技术,本文我们将介绍动态追踪技术Java Agent。
索码理
2022/12/28
9360
动态追踪之java agent
字节码调试的入口 —— JVM 的寄生插件 javaagent 那些事
Java Instrumentation 这个技术看起来非常神秘,很少有书会详细介绍。但是有很多工具是基于 Instrumentation 来实现的:
架构狂人
2023/08/16
1K0
字节码调试的入口 —— JVM 的寄生插件 javaagent 那些事
java agent使用与agent内存马
本质是一个jar包中的类,有两种实现,第一种是通过permain()函数实现。这种javaagent会在宿主程序的main函数的启动前启动自己premain函数,这时候会得到一个Instrumentation对象,我们可以通过Instrumentation对象对还未加载的class进行拦截与修改。
红队蓝军
2022/05/17
1.2K0
java agent使用与agent内存马
使用代理(Agent)的Java Bytecode Instrumentation:在运行时侵入Java应用程序(2)
来源: https://blogs.sap.com/2016/03/09/java-bytecode-instrumentation-using-agent-breaking-into-java-application-at-runtime/
java达人
2018/12/27
1.4K0
使用代理(Agent)的Java Bytecode Instrumentation:在运行时侵入Java应用程序(2)
谈谈Java Intrumentation和相关应用
  对于Java 程序员来说,Java Intrumentation、Java agent这些技术可能平时接触的很少,听上去陌生但又好像在哪里见到过。实际上,我们日常应用的各种工具中,有很多都是基于他们实现的,例如常见的热部署(JRebel, spring-loaded)、各种线上诊断工具(btrace, Greys)、代码覆盖率工具(JaCoCo)等等。   本文会介绍 Java Instrumentation及其相关概念,会涉及到的名词包括:
JavaEdge
2020/05/27
1.1K0
谈谈Java Intrumentation和相关应用
Java 调试工具、热部署、JVM 监控工具都用到了它
我们平时写 Java Agent 的机会确实不多,也可以说几乎用不着。但其实我们一直在用它,而且接触的机会非常多。下面这些技术都使用了 Java Agent 技术,看一下你就知道为什么了。
猿天地
2019/09/25
1K0
Java 调试工具、热部署、JVM 监控工具都用到了它
JVMTM Tool Interface:JVM源码分析之javaagent原理完全解读
本文重点讲述javaagent的具体实现,因为它面向的是我们Java程序员,而且agent都是用Java编写的,不需要太多的C/C++编程基础,不过这篇文章里也会讲到JVMTIAgent(C实现的),因为javaagent的运行还是依赖于一个特殊的JVMTIAgent。
一个会写诗的程序员
2020/05/18
1.7K0
JVMTM Tool Interface:JVM源码分析之javaagent原理完全解读
java运行时创建或修改类-JavaAgent
在运维监控系统开发过程中我们往往需要在特定的方法出入口进行记录日志、采集参数,甚至在特定场景下需要对方法的出入参数或者整个方法逻辑进行重写。目前市面上开源的APM系统主要有CAT、Zipkin、Pinpoint、SkyWalking,大都是参考Google的Dapper实现的。个人在项目中主要使用skywallking,在java、golang等多语言中有过实践,所以这里主要记录自己在java项目中使用skywallking的一些心得和笔记。
lelezc
2023/09/21
7270
java agent使用与agent内存马
本质是一个jar包中的类,有两种实现,第一种是通过permain()函数实现。这种javaagent会在宿主程序的main函数的启动前启动自己premain函数,这时候会得到一个Instrumentation对象,我们可以通过Instrumentation对象对还未加载的class进行拦截与修改。
红队蓝军
2022/04/13
1.4K0
java agent使用与agent内存马
Java基础知识:探针技术
启动前探针使用方式比较局限,而且每次探针更改的时候,都需要重新启动应用,而主程序之后的探针程序就可以直接连接到已经启动的 jvm 中。可以实现例如动态替换类,查看加载类信息的一些功能。
DioxideCN
2022/08/05
1.5K0
推荐阅读
相关推荐
Java Agent(一)、初步认识Instrumentation
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档