Home  >  Article  >  Database  >  mysql的设置自动提交失效问题_MySQL

mysql的设置自动提交失效问题_MySQL

WBOY
WBOYOriginal
2016-06-01 13:42:061245browse

bitsCN.com
工作几年了基本没用过mysql,悲催哈。。。今天在搞个小东西的时候用到mysql。一个很简单的问题,搞了几个小时,看来无知还是比较可怕的。。进入正题吧。问题很简单 JDBC 连接mysl 获取connnection 然后conn.setAutoCommit(false);重点来了 现在是要插入一条记录inset1......然后做一些逻辑处理,更新另一条数据 update2.。。最后conn.commit();当然catche里面还有 conn.rollback()。DEBUG时候发现 insert1执行完,数据库已经有值了。。原以为是隔离级别的问题,没在意。然后继续执行逻辑处理,出现异常conn.reollback()了。。此时再一看 插入的数据没有回滚。代码检查N次没查出问题。无奈又要问度娘,谷爷。。。此段时间乃是煎熬啊~~~~    最后还是有成果的。找到了个mysql表存储引擎的文章。 show create table 表名;
mysql的设置自动提交失效问题_MySQL
 可以看到ENGINE=MyISAMMyISAM是指Mysql的默认存储引擎,当create创建新表时,未指定新表的存储引擎时,默认使用Myisam。MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力既然有非事务表,就应该有支持事务的表了。没错,度娘又告诉我了 InnoDBInnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比Myisam的存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。 那就改吧。。 alter table 表名 engine=InnoDB; 然后再查看一下
mysql的设置自动提交失效问题_MySQL
 变成InnoDB了。。再跑次程序。。没错回滚了 。。。很小个问题。。。。但如果不了解Mysql的话也挺头痛的。。搞了几个小时。。。无知就是悲催哈。。。。 
 作者 北京—王志伟 bitsCN.com

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn