這里要講的巧妙用法是用來實現(xiàn)在攔截器中執(zhí)行額外 MyBatis 現(xiàn)有方法的用法。
創(chuàng)新互聯(lián)建站主要從事成都網(wǎng)站設(shè)計、網(wǎng)站制作、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)武清,十余年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792
并且會提供一個解決攔截Executor時想要修改MappedStatement時解決并發(fā)的問題。
這里假設(shè)一個場景:
實現(xiàn)一個攔截器,記錄 MyBatis 所有的 insert,update,delete 操作,將記錄的信息存入數(shù)據(jù)庫。
這個用法在這里就是將記錄的信息存入數(shù)據(jù)庫。
實現(xiàn)過程的關(guān)鍵步驟和代碼:
1.首先在某個 Mapper.xml 中定義好了一個往日志表中插入記錄的方法,假設(shè)方法為id="insertSqlLog"。
2.日志表相關(guān)的實體類為SqlLog.
3.攔截器簽名:
@Intercepts({@org.apache.ibatis.plugin.Signature( type=Executor.class, method="update", args={MappedStatement.class, Object.class})}) public class SqlInterceptor implements Interceptor
4.接口方法簡單實現(xiàn):
public Object intercept(Invocation invocation) throws Throwable { Object[] args = invocation.getArgs(); MappedStatement ms = (MappedStatement) args[0]; Object parameter = args[1]; SqlLog log = new SqlLog(); Configuration configuration = ms.getConfiguration(); Object target = invocation.getTarget(); StatementHandler handler = configuration.newStatementHandler((Executor) target, ms, parameter, RowBounds.DEFAULT, null, null); BoundSql boundSql = handler.getBoundSql(); //記錄SQL log.setSqlclause(boundSql.getSql()); //執(zhí)行真正的方法 Object result = invocation.proceed(); //記錄影響行數(shù) log.setResult(Integer.valueOf(Integer.parseInt(result.toString()))); //記錄時間 log.setWhencreated(new Date()); //TODO 還可以記錄參數(shù),或者單表id操作時,記錄數(shù)據(jù)操作前的狀態(tài) //獲取insertSqlLog方法 ms = ms.getConfiguration().getMappedStatement("insertSqlLog"); //替換當(dāng)前的參數(shù)為新的ms args[0] = ms; //insertSqlLog 方法的參數(shù)為 log args[1] = log; //執(zhí)行insertSqlLog方法 invocation.proceed(); //返回真正方法執(zhí)行的結(jié)果 return result; }
重點
MappedStatement是一個共享的緩存對象,這個對象是存在并發(fā)問題的,所以幾乎任何情況下都不能去修改這個對象(通用Mapper除外),想要對MappedStatement做修改該怎么辦呢?
并不難,Executor中的攔截器方法參數(shù)中都有MappedStatement ms,這個ms就是后續(xù)方法執(zhí)行要真正用到的MappedStatement,這樣一來,問題就容易解決了,根據(jù)自己的需要,深層復(fù)制MappedStatement對象中自己需要修改的屬性,然后修改這部分屬性,之后將修改后的ms通過上面代碼中args[0]=ms這種方式替換原有的參數(shù),這樣就能實現(xiàn)對ms的修改而且不會有并發(fā)問題了。
這里日志的例子就是一個更簡單的應(yīng)用,并沒有創(chuàng)建ms,只是獲取了一個新的ms替換現(xiàn)有的ms,然后去執(zhí)行。
總結(jié)
以上所述是小編給大家介紹的MyBatis Excutor 攔截器的巧妙用法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
網(wǎng)站題目:MyBatisExcutor攔截器的巧妙用法
文章源于:http://vcdvsql.cn/article8/peeoip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機、電子商務(wù)、小程序開發(fā)、云服務(wù)器、品牌網(wǎng)站設(shè)計、App開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)