mybatis怎么使用truncate清空表
小编给大家分享一下mybatis怎么使用truncate清空表,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
使用truncate清空表
Mapper接口
void truncateTable();
XML文件
<update id="truncateTable" > TRUNCATE TABLE 表名 </update>
注意:是<update>标签,不是<delete>标签
事务方法中使用truncate会发生什么
场景
在一个spring项目的事务方法中(使用@transactional注解):
首先执行一个delete语句;
然后执行一个truncate语句;
最后再执行一个insert语句;
问题
为什么delete语句和truncate语句执行成功,但insert语句虽然执行了,却没有提交?
解释
首先,在没有事务注解的方法中,一切与数据库的交互都是由mybatis处理的,
而mybatis默认是事务自动提交的,也就是每条sql语句执行完后会立即提交。
在添加事务注解后,应用与数据库的交互会由spring和mybatis共同处理(所以它们要共用同一个数据源):
spring管理事务,mybatis负责具体sql的执行。
那它们是如何协调的呢?
spring首先会在一开始创建连接开启事务,同时将连接放进当前线程(threadlocal);
mybatis执行sql语句时会从当前线程获取连接——这样就保证了spring和mybatis使用的是同一个连接;
mybatis执行sql后,会检查方法上是否有事务注解,如果有的话就不执行commit语句;
最后由spring执行commit。
这也就解释了一开始的问题:
执行完truncate后,当前事务已被提交(truncate虽然性能比delete好,但它是DDL语句,会触发事务提交),后续执行sql时,由于mybatis检测到事务注解所以不会提交
而spring此时早已把事务提交,也不会在方法结束时再一次提交了。
看完了这篇文章,相信你对“mybatis怎么使用truncate清空表”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网行业资讯频道,感谢各位的阅读!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341