MySQL和Oracle对比学习之事务

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: MySQL中的存储引擎很是丰富,常用的有InnoDB,MyISAM等,也查看了不少的资料,基本也有所了解,从一些参考书中看MySQL中的sql部分也是一扫而过,感觉和Oracle中的sql部分没有大的区别。
MySQL中的存储引擎很是丰富,常用的有InnoDB,MyISAM等,也查看了不少的资料,基本也有所了解,从一些参考书中看MySQL中的sql部分也是一扫而过,感觉和Oracle中的sql部分没有大的区别。
因为InnoDB和MyISAM存储引擎的一个主要区别就是对于事务的支持,所以自己也复制了oracle中的想法。
简单做了两个测试,只是想练手试一下,结果测试让我很意外。
我创建了两个表myisam_test和innodb_test,做一个insert操作,然后rollback,按照预期的想法,因为Myisam不支持事务,所以insert操作做rollback是不会回退的,对于innodb应该可以。
mysql> create table myisam_test(id int) engine=myisam;
Query OK, 0 rows affected (0.01 sec)
mysql> insert into myisam_test values(1);
Query OK, 1 row affected (0.00 sec)

mysql> select *from myisam_test;
+------+
| id   |
+------+
|    1 |
+------+
1 row in set (0.00 sec)

mysql> rollback;
Query OK, 0 rows affected (0.01 sec)

mysql> select *from myisam_test;               --这个结果也是预料之中的。
+------+
| id   |
+------+
|    1 |
+------+
1 row in set (0.00 sec)


再来试试InnoDB的部分,结果让我很意外。感觉自己的认知都出现了问题。
mysql> create table innodb_test(id int) engine=innodb;
Query OK, 0 rows affected (0.03 sec)

mysql> insert into innodb_test values(1);
Query OK, 1 row affected (0.01 sec)

mysql> select *from innodb_test;
+------+
| id   |
+------+
|    1 |
+------+
1 row in set (0.00 sec)

mysql> rollback;
Query OK, 0 rows affected (0.00 sec)

mysql> select *from innodb_test;
+------+
| id   |
+------+
|    1 |
+------+
1 row in set (0.00 sec)

相比于在oracle中,因为没有这些存储引擎,测试结果就取一个表ora_test吧。
SQL> create table ora_test(id number);
Table created.
SQL> insert into ora_test values(1);
1 row created.

SQL> select *from ora_test;
        ID
----------
         1
SQL> rollback;
Rollback complete.
SQL> select *from ora_test;
no rows selected

完全不同的结果,自己琢磨了下,Oracle中是隐式开启事务,对于一个session中的dml语句,就会自动开启事务,加入一把TX锁。
而在MySQL中却是需要使用start transaction来显示声明的。
其实在Oracle中也可以显示声明事务,可以使用savepoint来做。这一点上和MySQL是很类似的。
同是对于事务的提交方式上两者都是开放的,可以灵活的选择,在oracle中可以通过sqlplus或者驱动连接的设置。
SQL> set autocommit off;
SQL> show autocommit
autocommit OFF

在MySQL中式通过autocommit为1或者0来代表的。1代表自动提交,0表示禁用自动提交。
mysql> set autocommit=0;
Query OK, 0 rows affected (0.00 sec)

所以这个案例带给我们的启示就是很多细节只是需要自己尝试去实验,不要想当然;很多思想也不能想当然,可能在这个地方可用,在别的地方就不一定可用,这些细节不能忽视。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
21天前
|
SQL 关系型数据库 MySQL
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
|
存储 关系型数据库 MySQL
|
存储 关系型数据库 MySQL
|
16天前
|
SQL 存储 关系型数据库
6本值得推荐的MySQL学习书籍
本文是关于MySQL学习书籍的推荐,作者在DotNetGuide技术社区和微信公众号收到读者请求后,精选了6本值得阅读的MySQL书籍,包括《SQL学习指南(第3版)》、《MySQL是怎样使用的:快速入门MySQL》、《MySQL是怎样运行的:从根儿上理解MySQL》、《深入浅出MySQL:数据库开发、优化与管理维护(第3版)》以及《高性能MySQL(第4版)》和《MySQL技术内幕InnoDB存储引擎(第2版)》。此外,还有12本免费书籍的赠送活动,涵盖《SQL学习指南》、《MySQL是怎样使用的》等,赠书活动有效期至2024年4月9日。
|
21天前
|
SQL 关系型数据库 MySQL
轻松入门MySQL:深入学习数据库表管理,创建、修改、约束、建议与性能优化(3)
轻松入门MySQL:深入学习数据库表管理,创建、修改、约束、建议与性能优化(3)
|
1天前
|
存储 SQL 关系型数据库
MySQL学习手册(第一部分)
mysql日常使用记录
24 0
|
14天前
|
存储 SQL 关系型数据库
【MySQL实战笔记】03.事务隔离:为什么你改了我还看不见?-02
【4月更文挑战第7天】数据库通过视图实现事务隔离,不同隔离级别如读未提交、读已提交、可重复读和串行化采用不同策略。以可重复读为例,MySQL使用多版本并发控制(MVCC),每个事务有其独立的视图。回滚日志在无更早视图时被删除。长事务可能导致大量存储占用,应避免。事务启动可显式用`begin`或设置`autocommit=0`,但后者可能意外开启长事务。建议使用`autocommit=1`并显式管理事务,若需减少交互,可使用`commit work and chain`。
29 5
|
26天前
|
关系型数据库 MySQL 测试技术
面试-MySQL的四种事务隔离级别
面试-MySQL的四种事务隔离级别
18 0
|
存储 SQL 关系型数据库
|
27天前
|
存储 缓存 关系型数据库
MySQL事务的四大特性是如何保证的
在MySQL数据库中还有一种二进制日志,其用来基于时间点的还原及主从复制。从表面上来看其和重做日志非常相似,都是记录了对于数据库操作的日志。但是,从本质上来看有着非常大的不同。
13 1

推荐镜像

更多