mybatis sql 拦截器

SqlLogInterceptor

复制代码
@Component
@Intercepts({
        @Signature(type = StatementHandler.class, method = "query", args = {Statement.class, ResultHandler.class}),
        @Signature(type = StatementHandler.class, method = "update", args = {Statement.class})
})
@Slf4j
public class SqlLogInterceptor implements Interceptor {

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        long startTime = System.currentTimeMillis();
        Object retVal = invocation.proceed();
        try {
            long endTime = System.currentTimeMillis();
            long time = endTime - startTime;
            String traceId = TraceIdUtil.getTraceId();
            if (StringUtils.isNotEmpty(traceId)) {
                log.info("time" + time);
            }
        }catch (Exception e){
            log.error("error", e);
        }
        return retVal;
    }
}
相关推荐
dllxhcjla1 小时前
微服务全套
java
亚历克斯神1 小时前
JVM 内存管理 2026:深度解析与调优实战
java·spring·微服务
数厘1 小时前
2.1SQL 学习:先懂数据库概念再学 SQL
数据库·sql·学习
逻辑驱动的ken2 小时前
Java高频面试题:03
java·开发语言·面试·求职招聘·春招
广师大-Wzx2 小时前
一篇文章看懂MySQL数据库(下)
java·开发语言·数据结构·数据库·windows·python·mysql
野生技术架构师2 小时前
Java NIO到底是个什么东西?
java·开发语言·nio
likerhood3 小时前
简单工厂设计模式
java·ide·intellij-idea
派大星酷4 小时前
Java 调用 Kimi API 实战:实现与大模型的简单对话
java·开发语言·ai编程
spencer_tseng5 小时前
dameng CREATE USER
sql·dameng
猫耳球团5 小时前
IDEA与Cursor跨平台协作指南
java·ide·intellij-idea