关于数据库引擎为MyISAM ,但是却错误使用了事务语句。

1、创建表时指定了引擎为MyISAM。

2、某些操作为了提高效率,使用了事务提交。

3、MyISAM不支持事务,但是事务语句没有失败。

原因:当你在 MyISAM 表上执行包含 START TRANSACTION;INSERT INTO ...;COMMIT; 的语句时,这些语句本身在语法上是正确的,因此 MySQL 会正常执行这些命令。INSERT INTO ...; 语句会立即执行并影响表,而 START TRANSACTION;COMMIT; 虽然被执行,但对于 MyISAM 表实际上没有任何作用,它们不会产生事务控制的行为。因此,即便是在 MyISAM 表上,这样的命令序列也会"成功"执行,但成功的含义仅限于语法上的正确和 INSERT 操作的完成,并不意味着事务被正确处理。

如果你需要事务支持,建议使用支持事务的存储引擎,如 InnoDB。InnoDB 是 MySQL 的默认存储引擎,它提供了完整的 ACID 事务支持,适用于需要高可靠性和事务处理特性的应用场景。

相关推荐
敖云岚1 小时前
【Redis】分布式锁的介绍与演进之路
数据库·redis·分布式
LUCIAZZZ2 小时前
HikariCP数据库连接池原理解析
java·jvm·数据库·spring·springboot·线程池·连接池
我在北京coding2 小时前
300道GaussDB(WMS)题目及答案。
数据库·gaussdb
小Tomkk2 小时前
阿里云 RDS mysql 5.7 怎么 添加白名单 并链接数据库
数据库·mysql·阿里云
明月醉窗台3 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
沉到海底去吧Go4 小时前
【图片自动识别改名】识别图片中的文字并批量改名的工具,根据文字对图片批量改名,基于QT和腾讯OCR识别的实现方案
数据库·qt·ocr·图片识别自动改名·图片区域识别改名·pdf识别改名
老纪的技术唠嗑局4 小时前
重剑无锋,大巧不工 —— OceanBase 中的 Nest Loop Join 使用技巧分享
数据库·sql
未来之窗软件服务4 小时前
JAVASCRIPT 前端数据库-V6--仙盟数据库架构-—-—仙盟创梦IDE
数据库·数据库架构·仙盟创梦ide·东方仙盟·东方仙盟数据库
一只爱撸猫的程序猿6 小时前
构建一个简单的智能文档问答系统实例
数据库·spring boot·aigc
nanzhuhe6 小时前
sql中group by使用场景
数据库·sql·数据挖掘