解决myBatis中openSession()自动提交的问题

 更新时间:2024年09月27日 14:19:10   作者:xiaqin149  
在学习MySQL过程中,发现插入操作自动提交,问题原因可能是myBatis中的openSession()方法设置了自动提交,或者是MySQL的默认引擎设置为不支持事务的MyISAM,解决办法包括更改myBatis的提交设置或将MySQL表的引擎改为InnoDB

自动提交问题

跟着小破站视频写的代码,却发现我的插入操作自动提交了(视频中需要手动提交);

猜测是myBatis中有设置为自动提交的方法,于是百度了一下,果然

myBatis中自动提交设置

openSession() 方法有带参数为 autoCommit 的布尔值,即是否自动提交可以手动控制的。

  • 当openSession(true),即括号内为true的时候,mybaits是可以自动提交修改后的数据的
  • 当openSession(),即括号内为空(或false),为手动提交,需要最后调用 session.commit() 来完成数据更新操作

查完之后又看了一遍源码,发现我写的确实是openSession();里面并未添加true;然后又看了几篇csdn上的攻略还是没能解决问题

真实原因

最后想是不是MySQL的引擎问题呢,一开始我觉得应该不是,因为创表的时候我特意改过表的引擎就是为了能进行事务操作,所以应该是没问题的

emmmmm........ 不应当(晕)

然后看了我当时写的源码:

ALTER TABLE salgrade ENGINE = InnoDb;

好吧,是我写错了(也不知道为啥这里我总写错,这个好像ALTER TABLE 这些要大写,反正之前写小写不对),用了代码提示里的表,表改错了(晕),下次直接Navicat吧还是

最终解决方案

把t_student表的引擎改为InnoDB,就能解决问题了

MySQL的所有引擎中只有InnoDB支持事务,别的都会自动提交,所以如果需要实现事务功能,务必保证表的引擎为InnoDB哦

更改默认引擎

我百度了一下,说mysql-5.1版本之前默认引擎是MyISAM,之后是innoDB,但是我的默认却是MyISAM,不知道为啥(也有可能是我百度错了)

然后想着一劳永逸,直接把默认引擎改了得了,过程也不复杂;

在配置文件my.ini中的找到default-storage-engine,此时默认为MyISAM将等号后改为INNODB即可,当然这要先重启MySQL才能生效

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • spring的13个经典面试题

    spring的13个经典面试题

    Spring框架是一个开放源代码的J2EE应用程序框架,是针对bean的生命周期进行管理的轻量级容Spring解决了开发者在J2EE开发中遇到的许多常见的问题,我们这篇文章就来了解一下spring的面试题
    2021-06-06
  • Java Property类使用详解

    Java Property类使用详解

    这篇文章主要介绍了Java Property类使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • JAVA OOM内存溢出问题深入解析

    JAVA OOM内存溢出问题深入解析

    这篇文章主要为大家介绍了JAVA OOM内存溢出问题深入解析,在生产环境抢修中,我们经常会碰到应用系统java内存OOM的情况,这个问题非常常见,今天我们就这个问题来深入学习探讨一下
    2023-10-10
  • Spring详解使用注解开发流程

    Spring详解使用注解开发流程

    这篇文章主要为大家详细介绍了Spring如何使用注解开发,文中的示例代码讲解详细,对我们学习或工作有一定帮助,需要的可以参考一下
    2022-05-05
  • Java基于注解实现的锁实例解析

    Java基于注解实现的锁实例解析

    这篇文章主要介绍了Java基于注解实现的锁实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • SpringBoot整合达梦数据库的教程详解

    SpringBoot整合达梦数据库的教程详解

    这篇文章主要给大家介绍了SpringBoot整合达梦数据库的详细教程,文章中有详细的图片介绍和代码示例供大家参考,具有一定的参考价值,需要的朋友可以参考下
    2023-08-08
  • Java通过word模板实现创建word文档报告

    Java通过word模板实现创建word文档报告

    这篇文章主要为大家详细介绍了Java如何通过word模板实现创建word文档报告的教程,文中的示例代码讲解详细,感兴趣的小伙伴可以学习一下
    2022-09-09
  • 解决SpringBoot扫描不到公共类的实体问题

    解决SpringBoot扫描不到公共类的实体问题

    这篇文章主要介绍了解决SpringBoot扫描不到公共类的实体问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • Java数据结构之链表详解

    Java数据结构之链表详解

    本篇文章我们将讲解一种新型的数据结构—链表,链表是一种使用广泛的通用数据结构,它可以用来作为实现栈,队列等数据结构的基础.文中有非常详细的介绍,需要的朋友可以参考下
    2021-05-05
  • Java深入探索线程安全和线程通信的特性

    Java深入探索线程安全和线程通信的特性

    这篇文章主要介绍了Java线程安全和线程通信的特性,线程安全是多线程编程时的计算机程序代码中的一个概念。在拥有共享数据的多条线程并行执行的程序中,线程安全的代码会通过同步机制保证各个线程都可以正常且正确的执行,不会出现数据污染等意外情况
    2022-05-05

最新评论