mybatis的优化和补充
添加mybatis的sql日志
作用:可以帮我们再控制台显示sql执行语句,以便于查看sql是否写错
引入log4j依赖
<!--log4j-->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
日志文件
该文件名必须为log4j.properties,必须放在resources下
log4j.rootLogger=DEBUG, Console
#Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
log4j.logger.java.sql.ResultSet=INFO
log4j.logger.org.apache=INFO
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
为实体类起别名
把数据源信息提取到属性文件中
mybatis处理多个参数时
当xml中出现特殊字符时
在xml文件中出现特殊符号,处理方法有两种:
第一种是使用转义符: <:[ < ] >:[ > ] &:[&]
第二种是使用CDATA标签:<! [ CDATA [ sql语句 ] ]>
<select id="selectByAge" resultType="com.ykq.entity.Userinfo">
<![CDATA[select * from tbl_userinfo where age>#{minAge} and age<#{maxAge}]]>
</select>
获取主键递增的值
获取主键递增的值
模糊查询
在xml文件中使用concat函数进行字符串拼接
select * from 表名 where name like '%三%'
<select id="selectByLike" resultType="com.ykq.entity.Teacher">
select * from tbl_teacher where name like concat('%',#{name},'%')
</select>