mybatis設(shè)置sql執(zhí)行時(shí)間超時(shí)時(shí)間的方法
存在這樣的場(chǎng)景,當(dāng)一些比較耗時(shí)的查詢(xún)時(shí),如果不中斷,則會(huì)導(dǎo)致數(shù)據(jù)庫(kù)堵塞,進(jìn)而會(huì)拖垮整個(gè)數(shù)據(jù)庫(kù)服務(wù)的正常運(yùn)行。
1.如果你使用的是HikariCP連接池的話(huà),可以在配置文件設(shè)置connetion-timeout這個(gè)屬性(如application.properties)
2.如果你使用的是其他鏈接池,比如tomcat連接池,同時(shí)持久化框架用的是mybatis的話(huà),那可以這樣設(shè)置
2.1 在配置文件中設(shè)置全局的sql執(zhí)行超時(shí)時(shí)間(單位s):
mybatis.configuration.default-statement-timeout = 1
如果想把粒度更細(xì),比如粒度到某個(gè)sql的話(huà),可以在select/insert/update/delete 操作語(yǔ)句中設(shè)置 timeout值(單位s)
<select id="getXXXX" parameterType="java.lang.String" resultMap="dataMap" timeout="1"> ? </select>
當(dāng)sql執(zhí)行時(shí)間超過(guò)1s,就會(huì)斷開(kāi)操作了,起到保護(hù)數(shù)據(jù)庫(kù)服務(wù)的作用。
Mapper XML配置
還有一種方法是在mapper xml文件中對(duì)具體一個(gè)sql進(jìn)行設(shè)置,方法為在select/update/insert節(jié)點(diǎn)中配置timeout屬性,依然是以秒為單位表示超時(shí)時(shí)間并只作用于這一個(gè)sql.
<insert ? id="insertAuthor" ? parameterType="domain.blog.Author" ? flushCache="true" ? statementType="PREPARED" ? keyProperty="" ? keyColumn="" ? useGeneratedKeys="" ? timeout="20">
到此這篇關(guān)于mybatis設(shè)置sql執(zhí)行時(shí)間超時(shí)時(shí)間的方法的文章就介紹到這了,更多相關(guān)mybatis設(shè)置sql執(zhí)行時(shí)間內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
application.yml文件中如何開(kāi)啟mybatis自動(dòng)駝峰映射
這篇文章主要介紹了application.yml文件中開(kāi)啟mybatis自動(dòng)駝峰映射的方法,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08Java 將字符串動(dòng)態(tài)生成字節(jié)碼的實(shí)現(xiàn)方法
本篇文章主要是對(duì)Java將字符串動(dòng)態(tài)生成字節(jié)碼的實(shí)現(xiàn)方法進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-01-01SpringBoot項(xiàng)目實(shí)現(xiàn)MyBatis流式查詢(xún)的教程詳解
這篇文章主要介紹了SpringBoot項(xiàng)目如何實(shí)現(xiàn)MyBatis的流式查詢(xún),mybatis的流式查詢(xún),有點(diǎn)冷門(mén),實(shí)際用的場(chǎng)景比較少,但是在某些特殊場(chǎng)景下,卻是十分有效的一個(gè)方法,感興趣的同學(xué)可以參考一下2023-06-06關(guān)于Java如何用好線程池的方法分享(建議收藏)
這篇文章主要來(lái)和大家分享幾個(gè)關(guān)于Java如何用好線程池的建議,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解一下2023-06-06Springboot2.x+Quartz分布式集群的實(shí)現(xiàn)
這篇文章主要介紹了Springboot2.x+Quartz分布式集群的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09SpringBoot @PathVariable使用時(shí)遇到的問(wèn)題及解決
這篇文章主要介紹了SpringBoot @PathVariable使用時(shí)遇到的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10