如何在项目中打印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;
    }
}
相关推荐
焦糖布丁的午夜1 小时前
MySQL数据库大王小练习
数据库·mysql
狗头实习生2 小时前
Spring常见的事务失效原因
java·数据库·spring
冉冰学姐2 小时前
SSM泰兴市公交信息系统f504u(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架应用·泰兴市公交·息管理系统
2501_937193143 小时前
技术加持!PLB-TV:HDR10+UDP 传输
android·源码·源代码管理·机顶盒
偶像你挑的噻4 小时前
3.Qt-基础布局以及事件
开发语言·数据库·qt
Dxy12393102164 小时前
MySQL如何做读写分离架构
数据库·mysql·架构
霸王大陆5 小时前
《零基础学 PHP:从入门到实战》模块十:从应用到精通——掌握PHP进阶技术与现代化开发实战-2
android·开发语言·php
毕设十刻5 小时前
基于Vue的考勤管理系统8n7j8(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
合方圆~小文6 小时前
不同画面,三个镜头实时监控拍摄方案
数据结构·数据库·人工智能
ChrisitineTX7 小时前
凌晨突发Java并发问题:synchronized锁升级导致接口超时,排查过程全记录
java·数据库·oracle