博客首页 注册 建议与交流 排行榜 加入友情链接
推荐 投诉 搜索: 帮助

上帝他爷

分别担任CU、ITPUB以及CSDN社区的MySQL版主! 我本来想说我是吃屎的! ^_^
  yueliangdao0608.cublog.cn

关于作者
姓名:杨涛
职业:DBA
年龄:25
位置:中国-深圳
个性介绍:又长了一岁
QQ:38257291
MSN:yueliangdao0608@gmail.com
|| << >> ||
我的分类


[原创]MYSQL集群与INNODB事务处理的对比总结
举个例子吧。自己实验了一下。
对MYSQL的innodb 和 ndb 引擎对事务的处理
对于NDB
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

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

mysql> insert into foo values(1);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
mysql> commit;
ERROR 1296 (HY000): Got error 4350 'Transaction already aborted' from NDBCLUSTER
mysql> show errors;
+-------+------+--------------------------------------------------------------+
| Level | Code | Message                                                      |
+-------+------+--------------------------------------------------------------+
| Error | 1296 | Got error 4350 'Transaction already aborted' from NDB        |
| Error | 1296 | Got error 4350 'Transaction already aborted' from NDBCLUSTER |
| Error | 1180 | Got error 4350 during COMMIT                                 |
+-------+------+--------------------------------------------------------------+
3 rows in set (0.00 sec)

mysql> select * from foo;
Empty set (0.00 sec)
对于INNODB
mysql> create table foo2 (i int not null primary key) engine innodb;

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

mysql> insert into foo2 values(1);
Query OK, 1 row affected (0.00 sec)

mysql> insert into foo2 values(1);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
mysql> commit;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from foo2;
+---+
| i |
+---+
| 1 |
+---+
1 row in set (0.00 sec)
NDB遇到错误就终止了,回滚到最初的状态。
而INNODB遇到错误还是继续执行已经成功事务。

其他的等待测试。。。

发表于: 2007-12-19,修改于: 2008-02-19 18:36,已浏览701次,有评论3条 推荐 投诉


网友评论
网友: chensiping 时间:2008-02-19 16:58:11 IP地址:221.222.13.★
innodb在事务中遇到alter create之类的语句就自动commit了
所以你的第二个例子其实说明不了什么的

Blog作者的回复:
呵呵。我这个主要是表达NDB和INNODB对事务处理的情况的一些比较。
至于哪些语句自动提交或者不提交的,手册上讲的很清楚。


网友: chensiping 时间:2008-02-19 18:10:14 IP地址:221.222.13.★
结论是正确的,例子是有问题的

Blog作者的回复:
非常感谢。


网友: chensiping 时间:2008-02-19 18:17:49 IP地址:221.222.13.★
begin;
create table foo2 (i int not null primary key) engine innodb;
insert into foo2 values(1);
insert into foo2 values(1);
rollback;
select * from foo2;
+---+
| i |
+---+
| 1 |
+---+
__________________________
这是否说明innodb是不具备事务呢

把create语句放在事务前面吧,这样你的文章更完美一些,呵呵

Blog作者的回复:
谢谢提意见。这样的确会给人误解我要表达的意思。


 发表评论