mysql事务与存储引擎实例分析

一、MySQL事务

1、事务的概念

(1)事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。

(2)事务是一个不可分割的工作逻辑单元,在数据库系统上执行并发操作时,事务是最小的控制单元。

(3)多用户同时操作的数据库系统的场景,如银行、保险公司和证券交易系统等等,适用于事务处理。 (4)事务通过事务的整体性以保证数据的一致性。

2、事务的 ACID 特点

注:ACID,是指在可靠数据库管理系统 (DBMS) 中,事务 (transaction) 应该具有的四个特性:原子性 (Atomicity) 、一致性 (Consistency )、隔离性 (Isolation) 、持久性 (Durability) 。这是可靠数据库所应具备的几个特性。

(1)事务具有原子性,也就是说,事务中的操作要么全部执行,要么全部不执行,不可分割。 a、事务是一个完整的操作,事务的各元素是不可分的。

b、事务中的所有元素必须作为一个整体提交或回滚。

c、如果事务中的任何元素失败,则整个事务将失败。

(2)一致性:指在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。

a、当事务完成时,数据必须处于一致状态。

b、在事务开始前,数据库中存储的数据处于一致状态。

c、在正在进行的事务中,数据可能处于不一致的状态。

d、当事务成功完成时,数据必须再次回到已知的一致状态。

(3)隔离性:当多个事务同时操作相同的数据时,在并发环境中,每个事务都能够使用它自己独立的完整数据区域。 对数据进行修改的所有并发事务是彼此隔离的,表明事务必须是独立的,它不应以任何方式依赖于或影响其他事务。 修改数据的事务可在另一个使用相同数据的事务开始之前访问这些数据,或者在另一-个使用相同数据的事务结束之后访问这些数据。

(4)持久性:在事务完成以后,该事务对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。

a、指不管系统是否发生故障,事务处理的结果都是永久的。

b、一旦事务被提交,事务的效果会被永久地保留在数据库中。

总结:在事务管理中,原子性是基础,隔离性是手段,一致性是目的,持久性是结果。

3、事物之间的互相影响

(1)、脏读:一个事务读取了另一个事务未提交的数据,而这个数据是有可能回滚的。

在一个事务中连续执行两个相同的查询,却得到了不同的结果,这种情况被称为不可重复读。这是由于查询时系统中其他事务修改的提交而引起的。

重新叙述:幻读是指当一个事务修改了一个表中的某些数据行,但是另一个事务同时插入了几行新数据,导致第一个事务查询时发现多了几行数据。同时有另一个事务对该表进行了修改,并插入了一行新数据。操作前一个事务的用户会惊奇地发现表中仍有未修改的数据行,就像出现了幻觉一样。

(4)、丢失更新:两个事务同时读取同一条记录,A先修改记录,B也修改记录 (B不知道A修改过),B提交数据后B的修改结果覆盖了A的修改结果。

二、Mysql及事务隔离级别

(1) 、read uncommitted:读取尚未提交的数据,不解决脏读

(2)、 read committed:读取己经提交的数据,可以解决脏读

(3)、 repeatable read:重读读取,可以解决脏读和不可重复读————-mysql默认

(4)、 serializable:串行化,可以解决脏读不可重复读和虚读—————-相当于锁表 注:mysql 默认的事务处理级别是 repeatable read,而 Oracle 和 SQL Server 是 read committed

1、查询全局事务隔离级别

show global variables like '%isolation%';或select @@global.tx_isolation;

mysql事务与存储引擎实例分析

卡奥斯智能交互引擎 卡奥斯智能交互引擎

聚焦工业领域的AI搜索引擎工具

卡奥斯智能交互引擎 36 查看详情 卡奥斯智能交互引擎

2、查询会话事务隔离级别

show session variables like '%isolation%';SELECT @@session.tx_isolation; SELECT @@tx_isolation;

mysql事务与存储引擎实例分析

3、设置全局事务隔离级别

set global transaction isolation level read committed;show global variables like '%isolation%';

mysql事务与存储引擎实例分析

4、设置会话事务隔离级别

set session transaction isolation level read committed;show session variables like '%isolation%';

mysql事务与存储引擎实例分析

三、事务控制语句

1、相关语句

begin;               开启事务commit;              提交事务,使已对数据库进行的所有修改变为永久性的rollback;            回滚事务,撤销正在进行的所有未提交的修改savepoint s1;        建立回滚点,s1为回滚点名称,一个事务中可以有多个rollback to s1;      回滚到s1回滚点

2、案例

①、创建表

create database school;use school;create table Fmoney(id int(10) primary key not null,  name varchar(20),  money decimal(5,2));insert into Fmoney values ('1','srs1','100');insert into Fmoney values ('2','srs2','200');select * from Fmoney;

mysql事务与存储引擎实例分析

②、测试提交事务

begin;update Fmoney set money= money - 100 where name='srs2';commit;quitmysql -u root -puse school;select * from Fmoney;

mysql事务与存储引擎实例分析

③、测试回滚事务

begin;update Fmoney set money= money + 100 where name='srs2';select * from Fmoney;rollback;select * from Fmoney;

mysql事务与存储引擎实例分析

④、测试多点回滚

begin;update Fmoney set money= money + 100 where name='srs2';select * from Fmoney;savepoint a;update Fmoney set money= money + 100 where name='srs1';select * from Fmoney;savepoint b;insert into Fmoney values ('3','srs3','300');select * from Fmoney;rollback to b;select * from Fmoney;

mysql事务与存储引擎实例分析

mysql事务与存储引擎实例分析

3、使用 set 设置控制事务

SET AUTOCOMMIT=0;                        #禁止自动提交SET AUTOCOMMIT=1;                        #开启自动提交,Mysql默认为1SHOW VARIABLES LIKE 'AUTOCOMMIT';        #查看Mysql中的AUTOCOMMIT值

如果没有开启自动提交,当前会话连接的mysql的所有操作都会当成一个事务直到你输入rollback|commit;当前事务才算结束。当前事务结束前新的mysql连接时无法读取到任何当前会话的操作结果。
如果开起了自动提交,mysql会把每个sql语句当成一个事务,然后自动的commit。
当然无论开启与否,begin; commit|rollback; 都是独立的事务。

mysql事务与存储引擎实例分析

四、MySQL 存储引擎

1、存储引擎概念介绍

(1)MySQL中的数据用各种不同的技术存储在文件中,每一种技术都使用不同的存储机制、索引技巧、锁定水平,并最终提供不同的功能和能力,这些不同的技术以及配套的功能在MySQL中称为存储引擎。

(2)存储引擎是MySQL将数据存储在文件系统中的存储方式或者存储格式

(3)MySQL 常用的存储引擎有: a、MylSAM b、InnoDB

(4)MySQL数据库中的组件,负责执行实际的数据I/O操作

(5)MySQL系统中,存储引擎处于文件系统之.上,在数据保存到数据文件之前会传输到存储引擎,之后按照各个存储引擎的存储格式进行存储。

2、查看系统支持的存储引擎

show engines;

mysql事务与存储引擎实例分析

3、查看表使用的存储引擎

(1)方法一:直接查看show table status from 库名 where name='表名'G;例:show table status from school where name='class'G;(2)方法二:进入数据库查看use 库名;show create table 表名G;例:use school;show create table classG;

mysql事务与存储引擎实例分析

4、修改存储引擎

(1) 方法一:通过 alter table 修改use 库名;alter table 表名 engine=MyISAM;例:use school;alter table class engine=MYISAM;(2)方法二:通过修改 /etc/my.cnf 配置文件,指定默认存储引擎并重启服务注意:此方法只对修改了配置文件并重启mysql服务后新创建的表有效,已经存在的表不会有变更。vim /etc/my.cnf......[mysqld]......default-storage-engine=INNODBsystemctl restart mysql.service(3)方法三:通过 create table 创建表时指定存储引擎use 库名;create table 表名(字段1 数据类型,...) engine=MyISAM;例:mysql -u root -puse school;create table test7(id int(10) not null,name varchar(20) not null) engine=MyISAM;

mysql事务与存储引擎实例分析

mysql事务与存储引擎实例分析

mysql事务与存储引擎实例分析

以上就是mysql事务与存储引擎实例分析的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/269994.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 11:52:48
下一篇 2025年11月4日 11:54:07

相关推荐

  • RSS订阅如何数据分析?

    答案:RSS数据分析通过系统化流程挖掘内容趋势、发布者行为和商业洞察。首先利用Python、feedparser等工具抓取并存储数据,再通过pandas、BeautifulSoup清洗标准化,接着运用NLP、LDA等技术分析关键词与主题,结合发布频率、文章长度等指标评估内容质量,最后通过Plotly…

    好文分享 2025年12月17日
    000
  • 如何用C++处理XML文件?

    C++中处理XML需借助第三方库,因标准库无原生支持。推荐使用TinyXML-2或pugixml等轻量级DOM库,适用于中小型项目,API简洁易用;对大型或复杂场景可选Xerces-C++,支持SAX和DOM模式及Schema验证;性能敏感场景可考虑RapidXML,其零拷贝机制提升解析速度。处理大…

    2025年12月17日
    000
  • RSS订阅如何共享?

    共享RSS订阅可通过云端阅读器功能、OPML文件导出导入或自建RSS服务实现。云端工具如Feedly支持共享文件夹与团队协作,OPML提供跨平台通用备份与迁移,自建服务则保障数据隐私与定制化控制,适用于不同需求场景。 RSS订阅的共享,通常不是一个直接的“共享按钮”功能,而更多是基于特定服务或文件导…

    2025年12月17日
    000
  • XML处理性能如何优化?

    答案:优化XML处理性能需根据场景选择解析器,流式解析适合大文件以降低内存占用,避免DOM导致的内存溢出;通过优化XPath和XSLT、合理管理内存与GC、权衡Schema验证开销,并结合预处理与后处理策略提升整体效率。 优化XML处理性能,核心在于理解XML的特性,并根据实际应用场景选择最适合的解…

    2025年12月17日
    000
  • RSS如何实现分页加载?

    RSS协议本身不支持分页,因其设计为一次性推送最新内容;可通过服务器端动态生成带页码参数的Feed链接,或创建多个独立的历史存档Feed来模拟分页效果,但主流阅读器通常只订阅主URL,难以自动加载多页内容。 RSS本身的设计初衷,其实并没有直接内置“分页”这个概念。它更像是一个新闻快讯的广播台,一次…

    2025年12月17日
    000
  • XML与关系数据库如何映射?

    XML与关系数据库映射需根据数据结构和业务需求选择扁平化、父子表、聚合列等策略,结合数据库原生XML/JSON支持与混合建模,通过批量操作、事务管理、索引优化及增量同步等手段,在保证数据一致性的同时提升同步性能。 XML与关系数据库的映射,本质上是两种不同数据模型之间的“翻译”过程。XML以其树状、…

    2025年12月17日
    000
  • SOAP与数据库交互?如何连接数据库?

    SOAP通过中间层实现数据库交互,需接收并解析SOAP消息,连接数据库执行操作后返回响应;常见安全问题包括SQL注入、XXE、DoS及认证风险,应通过参数化查询、禁用外部实体、限流和RBAC等措施防范;性能优化可采用压缩、缓存、连接池、异步处理等手段;相比之下,RESTful API、GraphQL…

    2025年12月17日
    000
  • Kotlin怎么使用DOM方式解析XML配置文件?

    dom解析适用于文件较小且需频繁随机访问或修改的场景,局限性在于内存消耗大,不适合大文件解析;1. 使用documentbuilderfactory创建documentbuilder解析xml为document对象;2. 通过getelementsbytagname获取节点列表并遍历;3. 检查no…

    2025年12月17日
    000
  • RSS如何实现搜索功能?

    rss本身不提供搜索功能,需通过客户端或服务端实现。1.客户端本地搜索依赖阅读器存储的数据,优点是隐私性好,但仅限于已订阅内容;2.服务端搜索由网站提供,可搜索全部内容,速度快范围广;3.构建自定义搜索应用需考虑数据抓取、存储、索引、去重及用户界面设计。 RSS本身并没有内置的搜索功能。它更多是一种…

    2025年12月17日
    000
  • xml格式的数据库备份怎么恢复 分步指导恢复xml格式数据库备份文件

    要恢复xml数据库备份文件,需解析数据并插入对应表结构。具体步骤如下:一、确认xml结构,查看标签与表、字段的对应关系;二、准备目标数据库环境,确保表结构一致并处理主外键依赖;三、根据数据量选择恢复方式,小量可手动写sql插入,大量则用脚本(如python)自动解析并插入;四、恢复后执行查询验证数据…

    2025年12月17日
    000
  • xml怎么和数据库交互数据 实现xml与数据库数据交互的完整方案

    xml与数据库交互的核心是解析xml并映射字段至数据库表,具体步骤为:1.明确xml结构和数据库表结构;2.使用解析工具提取xml数据;3.通过参数化sql插入或更新数据库;4.从数据库查询数据并生成xml文件。整个过程需注意字段匹配、批量处理、空值及编码问题,确保数据准确性和完整性。 XML 和数…

    2025年12月17日
    000
  • 如何使用Golang实现基础论坛功能_Golang论坛模块拆解

    Golang论坛用户系统需实现注册、登录与权限管理:用Gin/Echo+GORM操作数据库,密码bcrypt哈希,JWT签发含user_id和role的token,中间件统一校验;注册校验唯一性,登录返回token及有效期,敏感操作按role严格控制。 用户系统:注册、登录与权限管理 论坛最基础的是…

    2025年12月17日
    000
  • Go中如何优雅处理数据库连接错误_Go DB Error处理方法

    Go中数据库错误处理核心是分层预防与精准归因:初始化时Ping验证连接,运行时用errors.Is和驱动错误类型区分网络超时、认证失败等场景,结合上下文超时与连接池配置实现可观测的健壮性。 Go 中处理数据库连接错误,关键不是“捕获 panic”,而是提前预防、分层判断、明确归因。标准库 datab…

    2025年12月17日
    000
  • 如何使用Golang反射构建灵活的工厂模式_Golang reflect工厂方法实现解析

    Golang反射工厂模式通过注册类型映射表实现运行时按名创建实例,支持带参构造与类型安全封装,适用于插件系统、配置驱动初始化等场景。 用 Golang 反射实现工厂模式,核心是绕过编译期类型绑定,让程序在运行时根据字符串、配置或用户输入动态创建结构体实例。它不替代传统接口+构造函数的工厂,而是解决“…

    2025年12月17日
    000
  • Golang如何优化数据库连接池使用_Golang数据库连接池性能管理实践

    合理配置Go的database/sql连接池可显著提升高并发服务性能。1. 理解连接池机制:SetMaxOpenConns控制最大并发连接,SetMaxIdleConns管理空闲连接,SetConnMaxLifetime和SetConnMaxIdleTime避免陈旧连接。2. 根据负载调优:OLTP…

    2025年12月16日
    000
  • Go database/sql 查询结果行数获取策略与实践

    在go语言的`database/sql`包中,直接获取`*sql.rows`返回的行数并非标准操作,因为它提供的是一个前向游标。本文将探讨两种主要策略:执行独立的`count(*)`查询(适用于分页等场景,但需注意竞态条件)和通过迭代`*sql.rows`游标进行计数(最可靠但需遍历全部结果)。我们…

    2025年12月16日
    000
  • 如何在Golang中开发问卷调查系统_Golang 问卷调查系统实战

    答案:基于Golang的问卷系统包含创建、发布、填写和查看结果功能,使用Gin框架与GORM操作数据库,通过HTML模板实现前端交互,结构清晰,便于扩展。 开发一个问卷调查系统在Golang中是一个实用且常见的项目,适合练习Web开发、数据库设计和用户交互处理。下面从需求分析到核心功能实现,一步步带…

    2025年12月16日
    000
  • Golang如何使用抽象工厂模式创建多产品族_Golang Abstract Factory模式应用技巧

    Go通过接口与组合实现抽象工厂模式,适用于创建多个相关产品族,如多数据库支持;定义产品与工厂接口,各产品族实现对应接口,结合配置动态切换工厂实例,提升系统可扩展性。 在Go语言中,虽然没有传统面向对象语言中的抽象类或接口继承机制,但通过接口(interface)和结构体组合,可以优雅地实现抽象工厂模…

    2025年12月16日
    000
  • Go database/sql:获取查询结果行数的策略与实践

    在go语言的`database/sql`包中,无法在不遍历结果集的情况下直接获取查询返回的行数。本文将深入探讨两种主流策略:一是通过独立的`count(*)`查询获取总行数,适用于分页场景但需注意并发问题;二是遍历`*sql.rows`结果集进行计数,确保获取实际处理的行数。我们将分析这两种方法的优…

    2025年12月16日
    000
  • Go语言中的Type Switch:深度解析接口类型判断机制

    本文深入探讨go语言中switch语句结合type关键字实现的类型切换(type switch)机制。它允许开发者在运行时根据接口变量的实际底层类型执行不同的代码逻辑,是处理多态性、实现灵活类型转换的关键工具,尤其适用于处理异构数据源或需要动态类型识别的场景,如数据库驱动和抽象语法树(ast)处理。…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信