2016 - 2024

感恩一路有你

mybatis打印sql语句到控制台 如何在mybatis中调试查看生成的sql语句?

浏览量:2650 时间:2021-03-17 15:49:49 作者:admin

如何在mybatis中调试查看生成的sql语句?

使用过hibernate的人都知道hibernate可以配置showusql显示自动生成的SQL语句,使用formatusql可以格式化SQL语句,但是如何使用mybatis来实现这个功能呢?在互联网上搜索之后,基本上是通过配置日志来实现的,比如log4j.properties,这是最常用的日志。Log4j.Properties content Log4j.Rootcategory=信息,标准输出,R Log4jappender.stdout=组织. apache.log4j.ConsoleAppender日志4j。appender.stdout.layout=组织. apache.log4j.pattern布局log4j。附录.stdout.layout.ConversionPattern=[QC]%p[%t]%C.%M(%L)|%M%n log4j.appender.R=org.apache.log4j.DailyRollingFileAppender log4j.appender.R.File=D:/myu日志.loglog4j.appender.R.layout=org.apache.log4j.pattern布局log4j.appender.R。布局。转换模式=%d-[TS]%p%t%c-%m%n log4j。logger.com.ibatis=调试log4j。logger.com.ibatis网站. common.jdbc.SimpleDataSource=调试log4j。logger.com.ibatis网站. common.jdbc.ScriptRunner=调试log4j。logger.com.ibatis网站. sqlmap.engine.impl文件.SqlMapClientDelegate=调试日志4j。记录器.java.sql.Connection=调试日志4j。记录器.java.sql.Statement=调试日志4j。记录器.java.sql. Preparedstatement=debug,stdout

在头条上问这个问题真是醉了。。顺便说一句,胡说八道太多了。

国内设计理念为表驱动。总之,逻辑是由数据表决定的,实现是由模型来完成的。事实上,这与面向对象的思想截然相反。大多数工程师手中所谓的mybatis的灵活性是,他们不需要考虑如何设计模型。”不管怎样,我可以用原生SQL来解决这个问题。模型设计太差了,只能靠SQL来修正。JPA是完全对象驱动的思想。早期设计的缺陷会制约后续的开发,不同的数据库可以用不同的方式实现(事实上,即使redis也是一样的)。回答一些常见的问题。

1. JPA表的连接行为具有不确定性和难以控制性。

您确定使用了spring数据JPA吗?不知道有实体图吗?当一个傻瓜达到这个水平时,他能做什么。

2. JPA子查询不容易实现。

我想你没用过,是吗?spring数据JPA的子查询不仅可以单独定义视图,还可以进行子查询,甚至可以直接使用jpql。

3. JPA不容易优化。

我真的不相信99%的优化能超过spring data JPA的优化。特别是,普通程序员能否停止谈论优化?他们甚至搞不懂MySQL的锁。表设计就像一堆废话,他们仍然每天使用原生SQL。你觉得他们很棒吗?JPA可以将表属性反映到对象。当然,运行时优化是有基础的。ORM的发展空间太大了。任何有点技术知识的人都知道ORM将拥有越来越多的优势。有一点经验的程序员都知道,在谈论其他人之前,是时候先谈论良好的维护了。解决性能问题的方法太多了。

最后,难道你不知道ORM cqrs现在是提倡的吗?请问,有没有什么复杂的问题没有原生SQL的介入是无法解决的。

SpringData JPA也能写sql,为什么还要用mybatis?

您可能已启用缓存。每次查询时,都会首先检查缓存。如果缓存失败,您将返回请求数据库。因为数据在第一次查询期间已加载到缓存中,所以第二次查询是缓存。如果未请求数据库,则不会显示SQL

mybatis打印sql语句到控制台 mybatis如何打印sql语句 mybatis配置打印sql语句

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。