zoukankan      html  css  js  c++  java
  • Mybatis辅助神器-MyBatis Log Plugin

    1. 问题描述

    Java操作数据库的两台流行天王-mybatis和hibernate,mytabis和hibernate的区别不想废话了,以前用hibernate,最近几年一直用的mybatis,目前Java连接数据库的方式基本都是preparedstatement,留好占位符,根据前端传入进行sql拼接,每个项目中总有那么几个:参数多,又是大于等于,又是日期转换,又是模糊查询的Sql,导致在数据库报错报错后,定位问题比较困难。

    Idea开启Debug模式,日志打印示例(示例比较简单,能说明问题就好):

    [http-nio-9107-exec-1] JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@f3a2023] will not be managed by Spring
    [http-nio-9107-exec-1] ==>  Preparing: select * from hp_config where status ='1' and type = ? ORDER BY type 
    [http-nio-9107-exec-1] ==> Parameters: 2(String)
    

    2. 解决方案

    使用mybatis插件神器:MyBatis Log Plugin,参数自动赋值到占位符中,生成数据库可执行SQL,将SQL复制到数据库中执行,就能很快定位到问题了。

    2.1 插件安装

    2.2 插件效果及说明

    插件可以在Idea的Tools下点击启动,也可以使用快捷键启动(ctrl+shift+alt+o)。

    需特别说明的是:

    要以Debug模式启动应用,并且日志级别也要是Debug。


  • 相关阅读:
    java timer 指定某时间点执行
    java jdbc 同时操作查询删除操作
    java ResultSet获得总行数
    c# 根据枚举Value 获得名称
    c# 备份数据
    MySQL主从集群搭建
    单机安装MySQL多实例
    2019年度总结
    go goroutine id
    go语言中 json转换--nil
  • 原文地址:https://www.cnblogs.com/ruanjianlaowang/p/11182612.html
Copyright © 2011-2022 走看看