查看Jasper报告执行的SQL

运行在报表文件(.jrxml)中嵌入SQL的Jasper报表时,是否可以看到执行的SQL? 理想情况下,我还希望看到替换每个$ P {}占位符的值。

干杯,

JasperReports使用Jakarta Commons Logging API。 Commons Logging有一个发现机制,可以连接到您在项目中使用的日志API。

您需要在日志记录配置文件中配置名为“net.sf.jasperreports”的记录器,以控制JasperReports的日志记录级别。

如果您使用的是Log4j,则可以阅读该文档的这一部分以获取确切的详细信息。

例如,您可以在log4j.properties文件中编写类似的内容

log4j.logger.net.sf.jasperreports = INFO,每日

其中“每日”是在同一属性文件中配置的appender的名称。

另一种选择是使用p6spy。 P6Spy是一种“代理JDBC驱动程序”,位于应用程序和真正的JDBC驱动程序之间,它可以记录它看到的所有内容。 您应该可以在此处下载副本: http : //www.p6spy.com/

如果您使用的是Ms SQL,则可以使用sql profiler查看服务器上执行的每个查询。

编辑:这是一篇关于在MySql服务器上启用sql查询日志的文章: http : //www.howtogeek.com/howto/database/monitor-all-sql-queries-in-mysql/

您可以调整log4j设置以记录正在运行的SQL …