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