前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL事务中更新多个表数据时,某些表不支持事务会发生什么???

MySQL事务中更新多个表数据时,某些表不支持事务会发生什么???

作者头像
码农编程进阶笔记
发布2021-11-12 15:39:10
1.9K0
发布2021-11-12 15:39:10
举报

我只在Mysql中做了测试,其它数据库各位读者如果有兴趣可以自己试试。

1. 创建测试数据

首先新建三张表:user、company、school。我们知道InnoDB引擎是支持事务的,而MyISAM引擎不支持事务,因此,在这里,我使用InnoDB作为user和school两个表的引擎,而使用MyISAM作为company的引擎。三个表结构很简单,数据类型什么的我就不放出来了,把表数据列在下面。

user表(InnoDB):

id

name

age

1

小明

18

2

小李

19

3

小张

20

company表(MyISAM):

id

name

age

1

小明的公司

小明的公司地址

2

小李的公司

小李的公司地址

3

小张的公司

小张的公司地址

school表(InnoDB):

id

name

age

1

小明的学校

小明的学校地址

2

小李的学校

小李的学校地址

3

小张的学校

小张的学校地址

2. 执行sql

测试sql如下:

BEGIN;
UPDATE user set age = '22' where id = 1;
UPDATE company set address = '小明的第二家公司地址' where id = 1;
UPDATE school set address = '小明的中学地址' where id = 1;
ROLLBACK;

上面的sql首先通过BEGIN启动一个事务,然后将user表中id为1的数据中age字段的值改为22,再将company表中id为1的数据中address字段的值改为‘小明的第二家公司’,第三条语句是将school表中id为1的数据中address字段的值改为‘小明的中学地址’,最后我们并不执行COMMIT来保存更改,而是使用ROLLBACK来回滚操作,看看是否都能正确回滚。

免费获取视频教程,微信搜索公众号:【码农编程进阶笔记】

最后的执行结果,由于company表使用了不支持事务的MyISAM引擎,所以,上述语句对company表数据的操作被真正的执行了,也就是说,company表中第一条数据中“小明的公司地址”被改成了“小明的第二家公司地址”,而其它两个表的数据没有发生任何变化。

3. 总结

在平时的工作中,如果涉及到数据库事务操作,一定要对库和表的性质特性了解清楚,以防一些不支持事务的库和表,影响了事务操作的原子性。

你的点赞关注是对我最大的支持,求一键三连:分享朋友圈、点赞、在看

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-11-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码农编程进阶笔记 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档