mybatis設置sql執(zhí)行時間超時時間的方法
存在這樣的場景,當一些比較耗時的查詢時,如果不中斷,則會導致數(shù)據(jù)庫堵塞,進而會拖垮整個數(shù)據(jù)庫服務的正常運行。
1.如果你使用的是HikariCP連接池的話,可以在配置文件設置connetion-timeout這個屬性(如application.properties)
2.如果你使用的是其他鏈接池,比如tomcat連接池,同時持久化框架用的是mybatis的話,那可以這樣設置
2.1 在配置文件中設置全局的sql執(zhí)行超時時間(單位s):
mybatis.configuration.default-statement-timeout = 1
如果想把粒度更細,比如粒度到某個sql的話,可以在select/insert/update/delete 操作語句中設置 timeout值(單位s)
<select id="getXXXX" parameterType="java.lang.String" resultMap="dataMap" timeout="1"> ? </select>
當sql執(zhí)行時間超過1s,就會斷開操作了,起到保護數(shù)據(jù)庫服務的作用。
Mapper XML配置
還有一種方法是在mapper xml文件中對具體一個sql進行設置,方法為在select/update/insert節(jié)點中配置timeout屬性,依然是以秒為單位表示超時時間并只作用于這一個sql.
<insert ? id="insertAuthor" ? parameterType="domain.blog.Author" ? flushCache="true" ? statementType="PREPARED" ? keyProperty="" ? keyColumn="" ? useGeneratedKeys="" ? timeout="20">
到此這篇關于mybatis設置sql執(zhí)行時間超時時間的方法的文章就介紹到這了,更多相關mybatis設置sql執(zhí)行時間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java中BigDecimal的舍入模式解析(RoundingMode)
這篇文章主要介紹了Java中BigDecimal的舍入模式解析(RoundingMode),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06
SpringBoot讀取properties文件配置項過程解析
這篇文章主要介紹了SpringBoot讀取properties文件配置項過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-06-06
SpringMVC整合SpringSession 實現(xiàn)sessiong
這篇文章主要介紹了SpringMVC整合SpringSession 實現(xiàn)session的實例代碼,本文通過實例相結合的形式給大家介紹的非常詳細,需要的朋友參考下吧2018-04-04
IDEA中springboot的熱加載thymeleaf靜態(tài)html頁面的方法
這篇文章主要介紹了IDEA中springboot的熱加載thymeleaf靜態(tài)html頁面的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07
mybatis如何使用Criteria的and和or進行聯(lián)合查詢
這篇文章主要介紹了mybatis如何使用Criteria的and和or進行聯(lián)合查詢,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12

