iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >mybatis如何使用truncate清空表
  • 195
分享到

mybatis如何使用truncate清空表

2024-04-02 19:04:59 195人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录使用truncate清空表Mapper接口XML文件事务方法中使用truncate会发生什么场景问题解释使用truncate清空表 Mapper接口 void truncateT

使用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此时早已把事务提交,也不会在方法结束时再一次提交了。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: mybatis如何使用truncate清空表

本文链接: https://www.lsjlt.com/news/142229.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mybatis如何使用truncate清空表
    目录使用truncate清空表Mapper接口XML文件事务方法中使用truncate会发生什么场景问题解释使用truncate清空表 Mapper接口 void truncateT...
    99+
    2022-11-13
  • mybatis怎么使用truncate清空表
    小编给大家分享一下mybatis怎么使用truncate清空表,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!使用truncate清空表Mapper接口void truncateTable();XML文件 ...
    99+
    2023-06-29
  • 用mybatis-plus清空teble表数据
    使用 MyBatis-Plus 清空表数据可以使用 IDeleteService#delete 方法。 首先,你需要在你的 Mapper 接口中声明 IDeleteService 接口,如下所示: public interface ...
    99+
    2023-09-11
    mybatis java 数据库 mysql spring
  • MySQL用truncate命令快速清空一个数据库中的所有表
    1. 先执行select语句生成所有truncate语句 语句格式: select CONCAT('truncate TABLE ',table_schema,'.',TABLE_NAM...
    99+
    2022-05-25
    MySQL truncate清空数据库表 MySQL truncate清空表
  • ubuntu如何清空route表
    ubuntu清空route表的方法:打开ubuntu系统,进入终端命令行。输入以下命令进行清空route表即可。sudo ip route flush table main...
    99+
    2022-10-20
  • centos7如何清空route表
    centos7中清空route表的方法:1、打开centos7终端;2、在命令行中输入“sudo ip route flush table main”命令清空route表即可。具体操作步骤:在centos7系统桌面中使用快捷键【Ctrl+A...
    99+
    2022-10-09
  • linux如何清空route表
    linux中清空route表的方法:1、打开linux终端;2、在命令行中输入“sudo ip route flush table main”命令清空route表即可。具体操作步骤:在linux系统桌面中使用快捷键【Ctrl+Alt+T】打...
    99+
    2022-10-18
  • MySQL中如何清空表数据
    目录MySQL清空表数据清空表数据一共有三种方式MySQL清空表数据命令:truncateMySQL删除表命令:dropMySQL清空数据表内容的语法:deleteMysq...
    99+
    2023-03-13
    MySQL清空表数据 MySQL清空数据 MySQL数据清空
  • MYSQL:如何清空表中的数据
    方法2 truncate from 表名; 比 较: 不带where参数的delete语句可以删除mysql表中所有内容,使用truncate table也可以清空mysql表中所有内容。 效率上truncate比delete快...
    99+
    2015-01-29
    MYSQL:如何清空表中的数据
  • 在PHP中如何使用正则表达式清除空格
    这篇文章将为大家详细讲解有关在PHP中如何使用正则表达式清除空格,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。正则表达式:php有什么特点1、执行速度快。2、具有很好的开...
    99+
    2022-10-19
  • oracle如何清空用户下所有表数据
    可以使用以下两种方法来清空Oracle用户下所有表的数据:1. 使用TRUNCATE命令:TRUNCATE命令可以快速清空表中的所有...
    99+
    2023-09-16
    oracle
  • mysql如何清空表中的数据库
    今天就跟大家聊聊有关mysql如何清空表中的数据库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。mysql如何清空表中的数据库1.进入MySQLmy...
    99+
    2022-10-18
  • 如何清空listview更新列表内容
    要清空ListView并更新其内容,可以按照以下步骤操作:1. 清空数据源:首先,清空用于存储数据的数据源,即List或ArrayL...
    99+
    2023-08-26
    listview
  • MYSQL清空表和截断表问题如何解决
    这篇文章主要介绍“MYSQL清空表和截断表问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MYSQL清空表和截断表问题如何解决”文章能帮助大家解决问题。MYSQL清空表和截断表清空表和截断...
    99+
    2023-07-05
  • 如何清空mysql数据库表的内容
    要清空MySQL数据库表的内容,可以使用TRUNCATE TABLE语句或DELETE FROM语句。1. 使用TRUNCA...
    99+
    2023-08-17
    mysql数据库
  • 如何在SQL中使用Truncate
    这篇文章给大家介绍如何在SQL中使用Truncate,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、Truncate语法[ { database_name.[&n...
    99+
    2022-10-18
  • jquery如何清空表格除前两行内容
    本篇内容介绍了“jquery如何清空表格除前两行内容”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • mysql中truncate函数如何使用
    truncate函数作用:mysql中truncate函数的作用是对一个数字按固定的小数点位数进行截取。truncate函数语法:SELECT TRUNCATE(num,radix_point);参数:num:表示需要截取的数字。radix...
    99+
    2022-10-15
  • Linux中如何使用Truncate命令
    这篇文章主要为大家展示了“Linux中如何使用Truncate命令”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中如何使用Truncate命令”这篇文章吧。Truncate命令通常用于...
    99+
    2023-06-15
  • JavaScript如何使用length调整/清空数组
    小编给大家分享一下JavaScript如何使用length调整/清空数组,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!使用 length 调整/清空数组我们基本上...
    99+
    2023-06-27
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作