如何在项目中打印sql和执行的时间

目标:打印DAO方法中sql和执行的时间

一种方式是去实现Mybatis的拦截器Interceptor ,比较麻烦;
这里介绍一种比较简单的实现方式;

1、如何打印sql?

配置文件加这个可以打印出com.zhenhui.ids.busi.watch包下执行的sql

xml 复制代码
logging.level.com.zhenhui.ids.busi.watch=debug

2、如何打印sql执行时间
com.zhenhui.ids.busi.watch 包下有多个子包,大部分子包下有DAO结尾的类,或者是Dao结尾

新建AOP切面类:MapperAspect

java 复制代码
package com.zhenhui.ids.busi.watch.config;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;

import java.util.Arrays;

@Aspect
@Component
@Slf4j
public class MapperAspect {

    @Pointcut("execution(* com.zhenhui.ids.busi.watch..*DAO.*(..))|| " +
            "execution(* com.zhenhui.ids.busi.watch..*Dao.*(..))) "
    )

    private void pointCutMethod() {

    }

    @Around("pointCutMethod()")
    public Object doAround(ProceedingJoinPoint pjp)  {
        long begin = System.nanoTime();
        Object obj = null;
        try {
            obj = pjp.proceed();
        }
        catch (Throwable throwable) {
            log.info("执行异常");
        }
        long end = System.nanoTime();

        log.info("调用Mapper方法:{},参数:{},\n耗时:{}毫秒",
                pjp.getSignature().toString(), Arrays.toString(pjp.getArgs()), (end - begin) / 1000000);
        return obj;
    }
}
相关推荐
zh157023几秒前
mysql如何给用户分配全局权限_合理使用GLOBAL权限层级
jvm·数据库·python
2303_821287381 分钟前
HTML怎么配合JavaScript交互_HTML DOM操作入门【指南】
jvm·数据库·python
m0_631529822 分钟前
SQL如何简化长SQL子查询结构_利用CTE公用表表达式优化
jvm·数据库·python
m0_740352423 分钟前
mysql安装完成后如何配置慢查询阈值_mysql日志监控方法
jvm·数据库·python
m0_740796363 分钟前
如何查找SQL中最常见的元素_结合GROUP BY与COUNT
jvm·数据库·python
wang3zc3 分钟前
HTML怎么标注成就连续打卡中断_HTML“断连,重新开始”提示【方法】
jvm·数据库·python
斌果^O^3 分钟前
SpringBoot 实战:@Async + CompletableFuture 实现多 SQL 并行统计查询
java·spring boot·sql
_376271533 分钟前
如何正确验证 GOPATH 和 PATH 环境变量是否生效
jvm·数据库·python
思麟呀3 分钟前
MySQL的库和表的操作
数据库·mysql
安当加密5 分钟前
数据库密码写配置文件?我用动态凭据管理重构了50个微服务的数据库连接
数据库·密码学·安全架构