欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis如何使用truncate清空表

 更新時(shí)間:2022年03月11日 15:43:19   作者:攻城日記  
這篇文章主要介紹了mybatis如何使用truncate清空表,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

使用truncate清空表

Mapper接口

void truncateTable();

XML文件

? <update id="truncateTable" >
? ? TRUNCATE TABLE 表名
? </update>

注意:是<update>標(biāo)簽,不是<delete>標(biāo)簽

事務(wù)方法中使用truncate會(huì)發(fā)生什么

場(chǎng)景

在一個(gè)spring項(xiàng)目的事務(wù)方法中(使用@transactional注解):

  • 首先執(zhí)行一個(gè)delete語(yǔ)句;
  • 然后執(zhí)行一個(gè)truncate語(yǔ)句;
  • 最后再執(zhí)行一個(gè)insert語(yǔ)句;

問(wèn)題

為什么delete語(yǔ)句和truncate語(yǔ)句執(zhí)行成功,但insert語(yǔ)句雖然執(zhí)行了,卻沒(méi)有提交?

解釋

首先,在沒(méi)有事務(wù)注解的方法中,一切與數(shù)據(jù)庫(kù)的交互都是由mybatis處理的,

而mybatis默認(rèn)是事務(wù)自動(dòng)提交的,也就是每條sql語(yǔ)句執(zhí)行完后會(huì)立即提交。

在添加事務(wù)注解后,應(yīng)用與數(shù)據(jù)庫(kù)的交互會(huì)由spring和mybatis共同處理(所以它們要共用同一個(gè)數(shù)據(jù)源):

spring管理事務(wù),mybatis負(fù)責(zé)具體sql的執(zhí)行。

那它們是如何協(xié)調(diào)的呢?

  • spring首先會(huì)在一開(kāi)始創(chuàng)建連接開(kāi)啟事務(wù),同時(shí)將連接放進(jìn)當(dāng)前線程(threadlocal);
  • mybatis執(zhí)行sql語(yǔ)句時(shí)會(huì)從當(dāng)前線程獲取連接——這樣就保證了spring和mybatis使用的是同一個(gè)連接;
  • mybatis執(zhí)行sql后,會(huì)檢查方法上是否有事務(wù)注解,如果有的話就不執(zhí)行commit語(yǔ)句;

最后由spring執(zhí)行commit。

這也就解釋了一開(kāi)始的問(wèn)題:

執(zhí)行完truncate后,當(dāng)前事務(wù)已被提交(truncate雖然性能比delete好,但它是DDL語(yǔ)句,會(huì)觸發(fā)事務(wù)提交),后續(xù)執(zhí)行sql時(shí),由于mybatis檢測(cè)到事務(wù)注解所以不會(huì)提交

而spring此時(shí)早已把事務(wù)提交,也不會(huì)在方法結(jié)束時(shí)再一次提交了。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java編寫(xiě)冒泡排序的完整示例

    java編寫(xiě)冒泡排序的完整示例

    這篇文章主要給大家介紹了關(guān)于java編寫(xiě)冒泡排序的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • JVM用寄存器實(shí)現(xiàn)程序計(jì)數(shù)

    JVM用寄存器實(shí)現(xiàn)程序計(jì)數(shù)

    這篇文章主要介紹了JVM用寄存器實(shí)現(xiàn)程序計(jì)數(shù),JVM中的程序計(jì)數(shù)寄存器(Program Counter Register),Register的命名源于CPU的寄存器,寄存器存儲(chǔ)指令相關(guān)的現(xiàn)場(chǎng)信息。CPU只有把數(shù)據(jù)裝載到寄存器才能夠運(yùn)行
    2023-02-02
  • springboot+vue實(shí)現(xiàn)七牛云頭像的上傳

    springboot+vue實(shí)現(xiàn)七牛云頭像的上傳

    本文將介紹如何在Spring Boot項(xiàng)目中利用七牛云進(jìn)行圖片上傳并將圖片存儲(chǔ)在云存儲(chǔ)中,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • Springboot使用cache緩存過(guò)程代碼實(shí)例

    Springboot使用cache緩存過(guò)程代碼實(shí)例

    這篇文章主要介紹了Springboot使用cache緩存過(guò)程代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • JAVA 實(shí)現(xiàn)磁盤(pán)文件加解密操作的示例代碼

    JAVA 實(shí)現(xiàn)磁盤(pán)文件加解密操作的示例代碼

    這篇文章主要介紹了JAVA 實(shí)現(xiàn)磁盤(pán)文件加解密操作的示例代碼,幫助大家利用Java實(shí)現(xiàn)文件的加解密,感興趣的朋友可以了解下
    2020-09-09
  • eclipse如何搭建Springboot項(xiàng)目詳解

    eclipse如何搭建Springboot項(xiàng)目詳解

    今天帶大家學(xué)習(xí)eclipse如何搭建Spring boot項(xiàng)目,文中有非常詳細(xì)的圖文解說(shuō),對(duì)正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-05-05
  • RabbitMQ消息單獨(dú)與批量的TTL詳細(xì)介紹

    RabbitMQ消息單獨(dú)與批量的TTL詳細(xì)介紹

    這篇文章主要介紹了RabbitMQ消息單獨(dú)與批量的TTL,TTL全名是Time To Live存活時(shí)間,表示當(dāng)消息由生產(chǎn)端存入MQ當(dāng)中的存活時(shí)間,當(dāng)時(shí)間到達(dá)的時(shí)候還未被消息就會(huì)被自動(dòng)清除,感興趣的同學(xué)可以參考下文
    2023-05-05
  • Java中LinkedHashSet的實(shí)現(xiàn)原理詳解

    Java中LinkedHashSet的實(shí)現(xiàn)原理詳解

    這篇文章主要介紹了Java中LinkedHasSet的實(shí)現(xiàn)原理詳解,LinkedHashSet?是具有可預(yù)知迭代順序的?Set?接口的哈希表和鏈接列表實(shí)現(xiàn),此實(shí)現(xiàn)與HashSet?的不同之處在于,后者維護(hù)著一個(gè)運(yùn)行于所有條目的雙重鏈接列表,需要的朋友可以參考下
    2023-09-09
  • Java利用POI實(shí)現(xiàn)導(dǎo)入導(dǎo)出Excel表格

    Java利用POI實(shí)現(xiàn)導(dǎo)入導(dǎo)出Excel表格

    這篇文章主要為大家詳細(xì)介紹了Java利用POI實(shí)現(xiàn)導(dǎo)入導(dǎo)出Excel表格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • java實(shí)現(xiàn)自動(dòng)回復(fù)聊天機(jī)器人

    java實(shí)現(xiàn)自動(dòng)回復(fù)聊天機(jī)器人

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)自動(dòng)回復(fù)聊天機(jī)器人,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08

最新評(píng)論