关闭
单冷 2022-04-19 02:24 采纳率: 60%
浏览 33
已结题

关于myabtis拦截器反射捕获异常问题

myabtis自定义拦截器,如何捕获数据库连接异常,如下代码能否捕获
@Override
public Object intercept(Invocation invocation) {
    Object target = invocation.getTarget();
    SqlCount.increment();
    System.out.println("current sql count = " + SqlCount.getValue());
    long startTime = System.currentTimeMillis();
    StatementHandler statementHandler = (StatementHandler) target;
    try {
        return invocation.proceed();
    }catch (Exception e){
        logger.info("-------------------------------------");
        System.out.println(e.getClass());
        return "fail";
    }finally {
        long endTime = System.currentTimeMillis();
        long timeCount = endTime - startTime;
        logger.info("执行 SQL:[ ]执行耗时[ {} ms]", timeCount);
    }
}
我在本地测试,关闭数据库后此实现并不能捕获netException
有什么方式可以在拦截器层面进行数据库连接异常的捕获吗
  • 写回答

1条回答 默认 最新

  • 编号灬9527 2022-04-19 02:34
    关注

    你拦截StatementHandler 那怎么能行,拦截Executor那才稳妥

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 4月26日
  • 已采纳回答 4月19日
  • 创建了问题 4月19日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部