欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis/MybatisPlus公共字段填充與配置邏輯刪除

 更新時(shí)間:2025年05月16日 10:13:18   作者:sjsjsbbsbsn  
MyBatis 和 MyBatis-Plus 都提供了相應(yīng)的機(jī)制來(lái)處理這些公共字段的填充和邏輯刪除,下面就來(lái)介紹一下,感興趣的可以了解一下

在開(kāi)發(fā)過(guò)程中,很多時(shí)候需要處理一些公共字段,例如:創(chuàng)建時(shí)間、修改時(shí)間、狀態(tài)字段等。這些字段通常會(huì)在插入或更新數(shù)據(jù)時(shí)進(jìn)行填充,以便記錄數(shù)據(jù)的變化和狀態(tài)。同時(shí),邏輯刪除也是常見(jiàn)的業(yè)務(wù)需求,比如刪除記錄并不是從數(shù)據(jù)庫(kù)中物理刪除,而是通過(guò)更新某個(gè)字段(如 is_deleted)來(lái)標(biāo)記數(shù)據(jù)已被刪除。

MyBatis 和 MyBatis-Plus 都提供了相應(yīng)的機(jī)制來(lái)處理這些公共字段的填充和邏輯刪除。下面我們將分別介紹如何在 MyBatis 和 MyBatis-Plus 中實(shí)現(xiàn)公共字段填充與邏輯刪除。

1.公共字段填充

mybatis:

在 MyBatis 中,公共字段填充可以通過(guò) TypeHandler 或者使用攔截器(Interceptor)來(lái)實(shí)現(xiàn)。但更為常見(jiàn)且方便的方式是通過(guò) 插件(例如 MyBatis Plus)來(lái)進(jìn)行全局配置。下面我們講解一種使用攔截器的方式來(lái)實(shí)現(xiàn)公共字段填充。

MyBatis 支持通過(guò)攔截器(Interceptor)來(lái)修改執(zhí)行的 SQL,或者在執(zhí)行時(shí)進(jìn)行公共字段的填充。你可以定義一個(gè) Interceptor,在插入或更新操作前對(duì)公共字段進(jìn)行填充:

@Intercepts({
    @Signature(type = StatementHandler.class, method = "prepare", args = {Connection.class, Integer.class})
})
@Component
public class MybatisInterceptor implements Interceptor {
    
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        // 獲取當(dāng)前執(zhí)行的 SQL
        StatementHandler statementHandler = (StatementHandler) invocation.getTarget();
        MappedStatement mappedStatement = (MappedStatement) invocation.getArgs()[0];
        BoundSql boundSql = statementHandler.getBoundSql();
        
        // 獲取 SQL 類(lèi)型(插入或更新)
        String sql = boundSql.getSql();
        if (sql.trim().toUpperCase().startsWith("INSERT")) {
            // 如果是插入操作,填充公共字段
            sql = addCommonFieldsForInsert(sql);
        } else if (sql.trim().toUpperCase().startsWith("UPDATE")) {
            // 如果是更新操作,填充公共字段
            sql = addCommonFieldsForUpdate(sql);
        }
        
        // 更新 SQL
        boundSql.setSql(sql);
        
        return invocation.proceed();
    }
    
    private String addCommonFieldsForInsert(String sql) {
        // 獲取當(dāng)前用戶信息(例如從 ThreadLocal 中獲取當(dāng)前用戶)
        String currentUser = getCurrentUser();
        
        // 添加創(chuàng)建時(shí)間、更新時(shí)間、創(chuàng)建人、更新人等字段
        sql = sql.replace("(", "(create_time, update_time, create_by, update_by, ");
        sql = sql.replace("values", "values(now(), now(), '" + currentUser + "', '" + currentUser + "', ");
        return sql;
    }
    
    private String addCommonFieldsForUpdate(String sql) {
        // 獲取當(dāng)前用戶信息(例如從 ThreadLocal 中獲取當(dāng)前用戶)
        String currentUser = getCurrentUser();
        
        // 替換 SQL,設(shè)置更新時(shí)間、更新人
        if (sql.contains("set")) {
            sql = sql.replaceFirst("set", "set update_time = now(), update_by = '" + currentUser + "', ");
        }
        return sql;
    }
    
    private String getCurrentUser() {
        // 模擬獲取當(dāng)前用戶,實(shí)際情況可以通過(guò) ThreadLocal 或 SecurityContext 獲取
        return "admin";  // 假設(shè)當(dāng)前用戶是 admin
    }

記得要把攔截器注冊(cè)

mybatis-plus:

通過(guò)實(shí)現(xiàn)MetaObjectHandler接口簡(jiǎn)化處理。

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.util.Date;

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        // 獲取當(dāng)前登錄用戶,假設(shè)是通過(guò) ThreadLocal 獲取當(dāng)前用戶
        String currentUser = getCurrentUser(); 
        
        this.strictInsertFill(metaObject, "createBy", String.class, currentUser);
        this.strictInsertFill(metaObject, "createTime", Date.class, new Date());
        this.strictInsertFill(metaObject, "updateBy", String.class, currentUser);
        this.strictInsertFill(metaObject, "updateTime", Date.class, new Date());
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        // 獲取當(dāng)前登錄用戶,假設(shè)是通過(guò) ThreadLocal 獲取當(dāng)前用戶
        String currentUser = getCurrentUser();

        this.strictUpdateFill(metaObject, "updateBy", String.class, currentUser);
        this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date());
    }

    private String getCurrentUser() {
        // 假設(shè)當(dāng)前用戶信息存儲(chǔ)在 ThreadLocal 中
        return "admin";  // 或者從上下文中獲取
    }
}

2.邏輯刪除:

1. MyBatis實(shí)現(xiàn)方式

需手動(dòng)修改所有SQL語(yǔ)句或在攔截器中添加條件。

XML映射文件示例

<select id="selectById" resultType="User">
    SELECT * FROM user WHERE id = #{id} AND is_deleted = 0
</select>

<update id="deleteById">
    UPDATE user SET is_deleted = 1 WHERE id = #{id}
</update>

運(yùn)行 HTML

2. MyBatis-Plus實(shí)現(xiàn)方式

提供全局配置和注解兩種方式。

方式1:全局配置(application.yml)

mybatis-plus:
  global-config:
    db-config:
      logic-delete-field: isDeleted   # 邏輯刪除字段名
      logic-delete-value: 1           # 刪除標(biāo)記值
      logic-not-delete-value: 0       # 未刪除標(biāo)記值

方式2:注解標(biāo)記

public class User {

    @TableLogic
    private Integer isDeleted;
}

方式3:Java配置類(lèi)

@Configuration
public class MyBatisPlusConfig {

    @Bean
    public GlobalConfig globalConfig() {
        GlobalConfig config = new GlobalConfig();
        GlobalConfig.DbConfig dbConfig = new GlobalConfig.DbConfig();
        dbConfig.setLogicDeleteField("isDeleted");
        dbConfig.setLogicDeleteValue("1");
        dbConfig.setLogicNotDeleteValue("0");
        config.setDbConfig(dbConfig);
        return config;
    }
}

到此這篇關(guān)于Mybatis/MybatisPlus公共字段填充與配置邏輯刪除的文章就介紹到這了,更多相關(guān)MybatisPlus公共字段填充與邏輯刪除內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

最新評(píng)論