前言
十載專注成都網(wǎng)站制作,成都企業(yè)網(wǎng)站建設(shè),個(gè)人網(wǎng)站制作服務(wù),為大家分享網(wǎng)站制作知識(shí)、方案,網(wǎng)站設(shè)計(jì)流程、步驟,成功服務(wù)上千家企業(yè)。為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì)及定制高端網(wǎng)站建設(shè)服務(wù),專注于成都企業(yè)網(wǎng)站建設(shè),高端網(wǎng)頁(yè)制作,對(duì)酒店設(shè)計(jì)等多個(gè)行業(yè),擁有多年的網(wǎng)站運(yùn)維經(jīng)驗(yàn)。
一般數(shù)據(jù)庫(kù)的表結(jié)構(gòu)都會(huì)有update_time,修改時(shí)間,因?yàn)檫@個(gè)字段基本與業(yè)務(wù)沒(méi)有太大關(guān)聯(lián),因此開(kāi)發(fā)過(guò)程中經(jīng)常會(huì)忘記設(shè)置這兩個(gè)字段的值,本插件就是來(lái)解決這個(gè)問(wèn)題。同樣的想生成id,create_time等操作都是可以以同樣的方式解決。想折騰的同學(xué)還可以通過(guò)這中方式自己寫(xiě)個(gè)分頁(yè)插件。
閑話少說(shuō)上代碼。
1. 先寫(xiě)一個(gè)自定義注解標(biāo)注是update_time
package com.zb.iscrm.annotation; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * @Auther: 楊紅星 * @Date: 2018/11/28 09:38 * @Description: */ @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.FIELD}) public @interface UpdateTime { String value() default ""; }
2. 寫(xiě)一個(gè)mybatis插件
使用@Intercepts標(biāo)注這是個(gè)mybatis插件,@Signature標(biāo)注要攔截的操作
package com.zb.iscrm.mybatisInterceptor; import com.zb.iscrm.annotation.UpdateTime; import com.zb.iscrm.utils.DateUtils; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.executor.Executor; import org.apache.ibatis.mapping.MappedStatement; import org.apache.ibatis.mapping.SqlCommandType; import org.apache.ibatis.plugin.*; import java.lang.reflect.Field; import java.util.Properties; /** * @Auther: 楊紅星 * @Date: 2018/11/28 09:41 * @Description: mybatis插件 用于執(zhí)行Update時(shí)將當(dāng)前時(shí)間加入 */ @Slf4j @Intercepts({ @Signature(type = Executor.class, method = "update", args = { MappedStatement.class, Object.class }) }) public class UpdateTimeInterceptor implements Interceptor { @Override public Object intercept(Invocation invocation) throws Throwable { MappedStatement mappedStatement = (MappedStatement) invocation.getArgs()[0]; // 獲取 SQL 命令 SqlCommandType sqlCommandType = mappedStatement.getSqlCommandType(); // 獲取參數(shù) Object parameter = invocation.getArgs()[1]; if (parameter != null) { // 獲取成員變量 Field[] declaredFields = parameter.getClass().getDeclaredFields(); for (Field field : declaredFields) { if (field.getAnnotation(UpdateTime.class) != null) { // update 語(yǔ)句插入 updateTime if (SqlCommandType.INSERT.equals(sqlCommandType) || SqlCommandType.UPDATE.equals(sqlCommandType)) { field.setAccessible(true); if (field.get(parameter) == null) { field.set(parameter, DateUtils.dateTimeNow(DateUtils.YYYY_MM_DD_HH_MM_SS)); } } } } } //同樣的方式也可以在這里添加create_time或者是id的生成等處理 return invocation.proceed(); } @Override public Object plugin(Object target) { return Plugin.wrap(target, this); } @Override public void setProperties(Properties properties) { } }
最后在mybatis的配置文件中注冊(cè)插件,然后就大功告成
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <!--插件注冊(cè)--> <plugins> <plugin interceptor="com.zb.iscrm.mybatisInterceptor.UpdateTimeInterceptor"/> </plugins> </configuration>
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。
文章標(biāo)題:mybatisInterceptor對(duì)UpdateTime自動(dòng)處理的實(shí)現(xiàn)方法
當(dāng)前地址:http://chinadenli.net/article0/ihoioo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、靜態(tài)網(wǎng)站、自適應(yīng)網(wǎng)站、網(wǎng)站策劃、小程序開(kāi)發(fā)、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)