强烈推荐一个大神的人工智能的教程:http://www.captainbed.net/zhanghan

描述

普通情况下,控制台打印出的sql是带?的,开发人员在自己调试的过程中遇到bug是再常见不过了,如果想看一下程序打出来的sql,发现参数的位置都是?,是不是很不爽,若想在数据库中执行sql,还需要手动修改sql的参数,真是麻烦,使用p6spy可以将sql格式化然后打出,打出的sql不再是带有?的,而是可以直接拷贝到数据库执行的。整合步骤如下:

添加jar包依赖

在service层添加依赖: ``` p6spy p6spy 3.7.0


</font>
<h1 id="背景"><table><tbody><tr><td bgcolor="#008B8B" height="40px"><font size="6px" face="华文新魏" color="white">自定义输出格式</font></td></tr></tbody></table></h1>
<font size="4px" face="楷体" font-weight="bold">

package com.zh.ssm.p6spy;

import com.p6spy.engine.spy.appender.MessageFormattingStrategy;

import java.text.SimpleDateFormat;
import java.util.Date;

/**

  • p6spy打印日志输出格式修改
  • 1.只打印最终执行的sql.
  • 2.sql换到下一行
  • 3.结尾处增加分号,以标示sql结尾

*/

public class P6SpyLogger implements MessageFormattingStrategy {
private SimpleDateFormat format = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss:SSS”);

public P6SpyLogger() {
}
public String formatMessage(int connectionId, String now, long elapsed, String category, String prepared, String sql) {return !"".equals(sql.trim())?this.format.format(new Date()) + " | took " + elapsed + "ms | " + category + " | connection " + connectionId + "\n " + sql + ";":"";
}

}

</font>
<h1 id="背景"><table><tbody><tr><td bgcolor="#008B8B" height="40px"><font size="6px" face="华文新魏" color="white">配置spy.properties</font></td></tr></tbody></table></h1>
<font size="4px" face="楷体" font-weight="bold">
在service层的classpath下新建文件spy.properties,内容如下:

#%L

P6Spy

%%

Copyright © 2013 P6Spy

%%

Licensed under the Apache License, Version 2.0 (the “License”);

you may not use this file except in compliance with the License.

You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software

distributed under the License is distributed on an “AS IS” BASIS,

WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

See the License for the specific language governing permissions and

limitations under the License.

#L%

#################################################################

P6Spy Options File

See documentation for detailed instructions

http://p6spy.github.io/p6spy/2.0/configandusage.html

#################################################################
#################################################################

MODULES

Module list adapts the modular functionality of P6Spy.

Only modules listed are active.

(default is com.p6spy.engine.logging.P6LogFactory and

com.p6spy.engine.spy.P6SpyFactory)

Please note that the core module (P6SpyFactory) can’t be

deactivated.

Unlike the other properties, activation of the changes on

this one requires reload.

#################################################################
#modulelist=com.p6spy.engine.spy.P6SpyFactory,com.p6spy.engine.logging.P6LogFactory,com.p6spy.engine.outage.P6OutageFactory
################################################################

CORE (P6SPY) PROPERTIES

################################################################

A comma separated list of JDBC drivers to load and register.

(default is empty)

Note: This is normally only needed when using P6Spy in an

application server environment with a JNDI data source or when

using a JDBC driver that does not implement the JDBC 4.0 API

(specifically automatic registration).

#driverlist=
driverlist=com.mysql.jdbc.Driver

for flushing per statement

(default is false)

#autoflush = false

sets the date format using Java’s SimpleDateFormat routine.

In case property is not set, miliseconds since 1.1.1970 (unix time) is used (default is empty)

#dateformat=

prints a stack trace for every statement logged

#stacktrace=false

if stacktrace=true, specifies the stack trace to print

#stacktraceclass=

determines if property file should be reloaded

Please note: reload means forgetting all the previously set

settings (even those set during runtime - via JMX)

and starting with the clean table

(default is false)

#reloadproperties=false
reloadproperties=true

determines how often should be reloaded in seconds

(default is 60)

#reloadpropertiesinterval=60

specifies the appender to use for logging

Please note: reload means forgetting all the previously set

settings (even those set during runtime - via JMX)

and starting with the clean table

(only the properties read from the configuration file)

(default is com.p6spy.engine.spy.appender.FileLogger)

#appender=com.p6spy.engine.spy.appender.Slf4JLogger
#appender=com.p6spy.engine.spy.appender.StdoutLogger
#appender=com.p6spy.engine.spy.appender.FileLogger
appender=com.p6spy.engine.spy.appender.Slf4JLogger

name of logfile to use, note Windows users should make sure to use forward slashes in their pathname (e:/test/spy.log)

(used for com.p6spy.engine.spy.appender.FileLogger only)

(default is spy.log)

#logfile = spy.log

append to the p6spy log file. if this is set to false the

log file is truncated every time. (file logger only)

(default is true)

#append=true

class to use for formatting log messages (default is: com.p6spy.engine.spy.appender.SingleLineFormat)

#logMessageFormat=com.p6spy.engine.spy.appender.SingleLineFormat
logMessageFormat=com.zh.ssm.p6spy.P6SpyLogger

format that is used for logging of the date/time/… (has to be compatible with java.text.SimpleDateFormat)

(default is dd-MMM-yy)

#databaseDialectDateFormat=dd-MMM-yy
databaseDialectDateFormat=yyyy-MM-dd HH:mm:ss

whether to expose options via JMX or not

(default is true)

#jmx=true

if exposing options via jmx (see option: jmx), what should be the prefix used?

jmx naming pattern constructed is: com.p6spy(.)?:name=

please note, if there is already such a name in use it would be unregistered first (the last registered wins)

(default is none)

#jmxPrefix=
#################################################################

DataSource replacement

Replace the real DataSource class in your application server

configuration with the name com.p6spy.engine.spy.P6DataSource

(that provides also connection pooling and xa support).

then add the JNDI name and class name of the real

DataSource here

Values set in this item cannot be reloaded using the

reloadproperties variable. Once it is loaded, it remains

in memory until the application is restarted.

#################################################################
#realdatasource=/RealMySqlDS
#realdatasourceclass=com.mysql.jdbc.jdbc2.optional.MysqlDataSource
#################################################################

DataSource properties

If you are using the DataSource support to intercept calls

to a DataSource that requires properties for proper setup,

define those properties here. Use name value pairs, separate

the name and value with a semicolon, and separate the

pairs with commas.

The example shown here is for mysql

#################################################################
#realdatasourceproperties=port;3306,serverName;myhost,databaseName;jbossdb,foo;bar
#################################################################

JNDI DataSource lookup

If you are using the DataSource support outside of an app

server, you will probably need to define the JNDI Context

environment.

If the P6Spy code will be executing inside an app server then

do not use these properties, and the DataSource lookup will

use the naming context defined by the app server.

The two standard elements of the naming environment are

jndicontextfactory and jndicontextproviderurl. If you need

additional elements, use the jndicontextcustom property.

You can define multiple properties in jndicontextcustom,

in name value pairs. Separate the name and value with a

semicolon, and separate the pairs with commas.

The example shown here is for a standalone program running on

a machine that is also running JBoss, so the JDNI context

is configured for JBoss (3.0.4).

(by default all these are empty)

#################################################################
#jndicontextfactory=org.jnp.interfaces.NamingContextFactory
#jndicontextproviderurl=localhost:1099
#jndicontextcustom=java.naming.factory.url.pkgs;org.jboss.nameing:org.jnp.interfaces
#jndicontextfactory=com.ibm.websphere.naming.WsnInitialContextFactory
#jndicontextproviderurl=iiop://localhost:900
################################################################

P6 LOGGING SPECIFIC PROPERTIES

################################################################

filter what is logged

please note this is a precondition for usage of: include/exclude/sqlexpression

(default is false)

#filter=false

comma separated list of strings to include

please note that special characters escaping (used in java) has to be done for the provided regular expression

(default is empty)

#include =

comma separated list of strings to exclude

(default is empty)

#exclude =

sql expression to evaluate if using regex

please note that special characters escaping (used in java) has to be done for the provided regular expression

(default is empty)

#sqlexpression =
#list of categories to exclude: error, info, batch, debug, statement,
#commit, rollback and result are valid values

(default is info,debug,result,resultset,batch)

#excludecategories=info,debug,result,resultset,batch
excludecategories=info,debug,result,resultset

Execution threshold applies to the standard logging of P6Spy.

While the standard logging logs out every statement

regardless of its execution time, this feature puts a time

condition on that logging. Only statements that have taken

longer than the time specified (in milliseconds) will be

logged. This way it is possible to see only statements that

have exceeded some high water mark.

This time is reloadable.

executionThreshold=integer time (milliseconds)

(default is 0)

#executionThreshold=
################################################################

P6 OUTAGE SPECIFIC PROPERTIES

################################################################

Outage Detection

This feature detects long-running statements that may be indicative of

a database outage problem. If this feature is turned on, it will log any

statement that surpasses the configurable time boundary during its execution.

When this feature is enabled, no other statements are logged except the long

running statements. The interval property is the boundary time set in seconds.

For example, if this is set to 2, then any statement requiring at least 2

seconds will be logged. Note that the same statement will continue to be logged

for as long as it executes. So if the interval is set to 2, and the query takes

11 seconds, it will be logged 5 times (at the 2, 4, 6, 8, 10 second intervals).

outagedetection=true|false

outagedetectioninterval=integer time (seconds)

(default is false)

#outagedetection=false

(default is 60)

#outagedetectioninterval=30

**注意:**该文件中的logMessageFormat=com.zh.ssm.p6spy.P6SpyLogger要配置为上一步自定义输出的类
</font>
<h1 id="背景"><table><tbody><tr><td bgcolor="#008B8B" height="40px"><font size="6px" face="华文新魏" color="white">修改数据库连接池配置</font></td></tr></tbody></table></h1>
<font size="4px" face="楷体" font-weight="bold">
在datasource.xml配置文件中做如下修改,添加如下代码
<bean id="dataSource" class="com.p6spy.engine.spy.P6DataSource"><constructor-arg><ref bean="dataSourceDefault"/></constructor-arg>
</bean><bean id="dataSourceDefault" class="com.alibaba.druid.pool.DruidDataSource"destroy-method="close"><property name="filters" value="stat"/><property name="url" value="${url}" /><property name="username" value="${username}" /><property name="password" value="${password}" /><property name="keepAlive" value="true"/><!--最大连接数--><property name="maxActive" value="20" /><property name="initialSize" value="1" /><property name="maxWait" value="60000" /><property name="minIdle" value="1" /><property name="timeBetweenEvictionRunsMillis" value="60000" /><property name="minEvictableIdleTimeMillis" value="300000" /><property name="testWhileIdle" value="true" /><property name="testOnBorrow" value="false" /><property name="testOnReturn" value="false" /><property name="poolPreparedStatements" value="true" /><property name="maxOpenPreparedStatements" value="20" /><!--配置>0时,会检查activeCount是否大于onFatalErrorMaxActive,如果大于则抛异常。--><property name="onFatalErrorMaxActive" value="1" />
</bean>

</font>
<h1 id="背景"><table><tbody><tr><td bgcolor="#008B8B" height="40px"><font size="6px" face="华文新魏" color="white">修改log4j.properties</font></td></tr></tbody></table></h1>
<font size="4px" face="楷体" font-weight="bold">
添加如下内容:

##p6spy
log4j.logger.p6spy=info,spyConsole
#配置p6spy打印输出到控制台并定义其格式
log4j.appender.spyConsole = org.apache.log4j.ConsoleAppender
log4j.appender.spyConsole.Target=System.out
log4j.appender.spyConsole.layout = org.apache.log4j.PatternLayout
log4j.appender.spyConsole.layout.ConversionPattern = #####-----%m%n


</font>
<h1 id="背景"><table><tbody><tr><td bgcolor="#008B8B" height="40px"><font size="6px" face="华文新魏" color="white">效果展示</font></td></tr></tbody></table></h1>
<font size="4px" face="楷体" font-weight="bold">
打印出的sql格式为:

#####-----2018-07-09 20:20:30:238 | took 51ms | statement | connection 0
SELECT * FROM tb_user WHERE id = ‘1’;

</font>
<h1 id="背景"><table><tbody><tr><td bgcolor="#008B8B" height="40px"><font size="6px" face="华文新魏" color="white">博客推荐</font></td></tr></tbody></table></h1>
<font size="4px" face="楷体" font-weight="bold">1. 想配置更多的输出日志?请看这里:https://blog.csdn.net/lk_blog/article/details/50768287?locationNum=15&fps=12. 想知道为什么如此配置数据源吗?请看:https://blog.csdn.net/sanyuedexuanlv/article/details/513312093. https://www.cnblogs.com/luodengxiong/p/6766357.html</font>

SSM框架搭建(三)--整合p6spy相关推荐

  1. ssm框架搭建和整合流程

    Spring + SpringMVC + Mybatis整合流程 1      需求 1.1     客户列表查询 1.2     根据客户姓名模糊查询 2      整合思路 第一步:整合dao层 ...

  2. SSM框架搭建,及遇到的问题

    SSM框架搭建,及遇到的问题 1.基本概念 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Exp ...

  3. java二维码生成 使用SSM框架 搭建属于自己的APP二维码合成、解析、下载

    java二维码生成 使用SSM框架 搭建属于自己的APP二维码合成.解析.下载 自己用java搭建一个属于自己APP二维码合成网站.我的思路是这样的: 1.用户在前台表单提交APP的IOS和Andro ...

  4. ssm框架搭建连接mysql_SSM框架集搭建

    SSM(Spring+SpringMVC+Mybatis)框架集由Spring.SpringMVC.Mybatis三个开源框架整合而成,常作为数据源较简单的web项目的框架. 1.三大框架概述 Spr ...

  5. 小菜鸟的SSM框架搭建【详细步骤】【SSM/IDEA/MAVEN】

    小菜鸟的SSM框架搭建 内容很长噢,一步步搭建 此框架是跟着b站上的黎曼的猜想所发布的视频搭建起来的,细节操作可以看视频.我只是在这里梳理一下ssm框架搭建的流程. 整合说明:SSM整合可以使用多种方 ...

  6. SSM框架搭建(四) springmvc和mybatis的配置

    SSM框架搭建(一) JDK和MAVEN环境搭建 SSM框架搭建(二) 创建MAVEN项目 SSM框架搭建(三) 数据库创建和MyBatis生成器自动生成实体类.DAO接口和Mapping映射文件 S ...

  7. ssm框架搭建连接mysql_从零开始搭建SSM框架(Spring + Spring MVC + Mybatis)

    最近在回顾和总结一些技术,想到了把之前比较火的 SSM 框架重新搭建出来,作为一个小结,同时也希望本文章写出来能对大家有一些帮助和启发,因本人水平有限,难免可能会有一些不对之处,欢迎各位大神拍砖指教, ...

  8. javaweb成长之路:SSM框架搭建

    学习javaweb开发,框架的学习是难以避免的,合理的使用框架进行开发,可以很大程度的提升开发效率,减少开发者的工作量.随着it行业的不断发展,各种框架也是层出不穷,目前使用最广的框架应该是属于ssm ...

  9. SSM框架搭建详细解析

    总结了一下搭建SSM框架流程,在以后用到的时候方便回头使用. 使用工具:MyEclipse 2015:Tomcat 8版本:jdk1.8版本. 首先: 1:创建一个WebProject项目,jdk1. ...

最新文章

  1. 深度学习实战讲词嵌入 很好的 NLP电子书
  2. python常考题_python面试总结2(函数常考题和异常处理)
  3. pytorch笔记——简易回归问题
  4. 分式求和python_python实现利用留数定理分解分式多项式
  5. 编译hotspot_从Hotspot JIT编译器打印生成的汇编代码
  6. python关键词提取_python对文件中的关键词查找替换,实现自动获取配置
  7. VMware发布面向未来的员工工作解决方案,满足分散办公需求
  8. python字符串的切片方式是[n、m、不包括m_python字符串的操作(去掉空格strip(),切片,查找,连接join(),分割split(),转换首字母大写, 转换字母大小写...)...
  9. jsp mysql事务锁_学生会事务管理系统的设计与实现(JSP,MySQL)(含录像)
  10. 2018年AI如何发展?普华永道做出了8点预测 | 报告下载
  11. 局域网 ARP 欺骗原理详解
  12. C#之FileInfo的简单操作
  13. 卸载HP LaserJet 激光打印机的驱动程序--Win7环境
  14. 学习笔记:AGPS-SUPL架构
  15. 手把手带你Yolov5 (v6.x)添加注意力机制(一)(并附上30多种顶会Attention原理图)(新增8种)
  16. 惠普总裁口述的职业规划(3)
  17. 介绍现有三大前端框架-思想
  18. LVGL8学习之msgbox
  19. dp hdu5653 xiaoxin and his watermelon candy
  20. 仪表放大器 电流的检测

热门文章

  1. nvme固态必须uefi启动吗_【Ubuntu】UEFI安装Windows 10和Ubuntu 18.04双系统(深度爬坑)...
  2. 自学笔记之计算机网络(3)--奈奎斯特定理与香农定理
  3. jPlayer播放后台返回的语音流
  4. 快讯 | 依斯特与嘉益仕(Litns)再续合作,共建智慧供应链平台
  5. java舆情监控类软件_java舆情监测系统
  6. JS初练——弹弹球与墙壁碰撞处理实例
  7. nginx-反向代理和负载均衡
  8. 阿里研究员、饿了么CTO等10位技术大咖倾囊相授:全方位解读研发效能提升之道!...
  9. linux 程序 减肥,linux下实用软件组合 -- 为你的 linux 减肥!
  10. 对壁纸窗口(Wallpaper Window)的管理分析