mybatis学习之路----打印sql语句
来源:互联网 发布:淘宝30天最低价 编辑:程序博客网 时间:2024/06/05 20:26
点滴记载,点滴进步,愿自己更上一层楼。
用mybatis执行数据库操作仅仅能看到执行结果,如果想看到执行的sql语句怎么办。
查阅mybatis官方文档找到了解决方法。
官方文档传送门
配置什么的很简单,用的log4j打印,当然参照官方文档还有好几种方法,具体自弄。这里仅作记录只用。
配置很简单,将log4j架包加入到classpath里。
maven配置。
<dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency>非maven项目只需要将jar添加到项目中即可。
log4j.properties添加到source根目录。
# Global logging configurationlog4j.rootLogger=ERROR, stdout# MyBatis logging configuration...#log4j.logger.com.soft.test.dao=DEBUGlog4j.logger.dynamic=DEBUG#log4j.logger.org.mybatis.example.BlogMapper=TRACE# Console output...log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n其中关键的地方是
log4j.logger.dynamic=DEBUG
log4j.logger是固定的,dynamic为你的mapper.xml的namespace
如果我的xml中的namespace为dynamic
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- namespace命名空间,跟java的package类似,避免sql id重复,有了这个命名空间,别的xml中的sql的id可以跟这个重复,并且 namespace不能省略,不能为空,不用接口开发,此处可以随意写--><mapper namespace="dynamic"> <resultMap id="userMap" type="com.soft.test.model.User"> <id column="id" property="id"/> <result column="username" property="username"/> <result column="password" property="password"/> <result column="create_date" property="createDate"/> </resultMap> <!--if 标签使用类似html的C标签的if --> <select id="selectUseIf" parameterType="com.soft.test.model.User" resultMap="userMap"> select * from t_user where <if test="id != null and id != ''"> id=#{id} </if> <if test="username != null and username != ''"> and username like concat('%',#{username},'%') </if> <if test="password != null and password != ''"> and password=#{password} </if> </select> </mapper>配置完成。现在运行测试即可看到运行的sql语句
------------------------------------------------------------------------------------------------------------------------------
DEBUG [main] - ==> Preparing: select * from t_user where id=? and username like concat('%',?,'%')
DEBUG [main] - ==> Parameters: 28(Integer), xiao(String)
DEBUG [main] - <== Total: 1
-------------------------------------------------------------------------------------------------------------------------------
记录到此结束。
- mybatis学习之路----打印sql语句
- mybatis 打印sql语句
- mybatis 打印sql语句
- mybatis打印sql语句
- 打印 mybatis sql 语句
- Mybatis 打印SQL语句
- mybatis 打印SQL语句
- MyBatis控制台打印Sql语句
- Mybatis设置打印sql语句
- mybatis 打印sql语句配置
- mybatis 打印sql执行语句
- mybatis的Sql语句打印
- mybatis打印出sql语句
- logback打印mybatis sql语句
- mybatis如何打印sql语句
- Mybatis配置之请求数据库时打印SQL语句
- MyBatis学习 之 三、动态SQL语句
- MyBatis学习 之 三、动态SQL语句
- UART串口通信浅谈之(二)--寄存器设置
- Android 5.1获取IP
- URL与资源
- SSH框架的基本整合
- Java设计模式——代理模式(Proxy Pattern)
- mybatis学习之路----打印sql语句
- C#中的 具名参数 和 可选参数
- ORA-00911: invalid character
- 获取war包中配置文件路径API
- TypeError: super(type, obj): obj must be an instance or subtype of type
- 字符串查找(文件路径查找)
- Java 并发编程(三)线程管理
- java中的注解大全@controller、@service、@repository等
- C++11学习之匿名函数lambda表达式