• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

mysql 搞代码 4年前 (2022-01-09) 9次浏览 已收录 0个评论

gaodaima.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 表名;

可以看到ENGINE=MyISAM来源gaodai#ma#com搞@代~码$网MyISAM是指Mysql的默认存储引擎,当create创建新表时,未指定新表的存储引擎时,默认使用Myisam。MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力既然有非事务表,就应该有支持事务的表了。没错,度娘又告诉我了 InnoDBInnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比Myisam的存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。 那就改吧。。 alter table 表名 engine=InnoDB; 然后再查看一下

变成InnoDB了。。再跑次程序。。没错回滚了 。。。很小个问题。。。。但如果不了解Mysql的话也挺头痛的。。搞了几个小时。。。无知就是悲催哈。。。。
作者 北京—王志伟 gaodaima.com


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql的设置自动提交失效问题_MySQL
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址