日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Mybatis —— @Options注解实现执行参数配置

發(fā)布時(shí)間:2023/12/14 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Mybatis —— @Options注解实现执行参数配置 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

記錄下Mybtias注解方式如何配置 SQL執(zhí)行超時(shí)時(shí)長(zhǎng)、Statement類型等

一、背景

最近使用Presto和Trino引擎做SQL執(zhí)行開銷埋點(diǎn)(這個(gè)找時(shí)間也寫篇博客記錄下),實(shí)施過(guò)程中發(fā)現(xiàn)有個(gè)應(yīng)用請(qǐng)求的SQL被分成了兩個(gè)過(guò)程 —— Prepare階段Execute階段

這帶來(lái)了什么問(wèn)題呢?
造成了SQL和實(shí)際執(zhí)行開銷沒(méi)能直接對(duì)上。 利用Trino Http Event Client監(jiān)聽查詢完成事件時(shí),PreparedStatement執(zhí)行方式會(huì)將SQL割裂,Prepared階段的event記錄了SQL,但缺少執(zhí)行開銷;Execute階段有執(zhí)行開銷,但沒(méi)有具體執(zhí)行的SQL內(nèi)容。

二、解決方式

核心:從PreparedStatement方式轉(zhuǎn)為Statement方式
如果是mapper文件方式可以在標(biāo)簽屬性里設(shè)置,但原來(lái)調(diào)用代碼是注解方式,該如何實(shí)現(xiàn)呢?

通過(guò)@Options注解指定statementType即可實(shí)現(xiàn),其他可配置參數(shù)請(qǐng)參考源碼類

// 原本調(diào)用方式@Select("${executeSql}")String executeTaskSql(@Param("executeSql") String executeSql);// 變更后調(diào)用方式@Select("${executeSql}")@Options(timeout = 2400, statementType = StatementType.STATEMENT)String executeTaskSqlByStatement(@Param("executeSql") String executeSql);

總結(jié)

以上是生活随笔為你收集整理的Mybatis —— @Options注解实现执行参数配置的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。