pojo实体类:
package org.westos.pojo;
public class User {
private int id;
private String name;
private String password;
public User() {
}
public User(int id, String name, String password) {
this.id = id;
this.name = name;
this.password = password;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
", password='" + password + '\'' +
'}';
}
}
数据库对应字段:
查询接口:
package org.westos.dao;
import org.westos.pojo.User;
import java.util.List;
public interface UserMapper {
List<User> getUser();
}
映射文件:
<mapper namespace="org.westos.dao.UserMapper">
<select id="getUser" resultType="User">
select * from user;
select>
mapper>
查询结果:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GXiold2B-1597284746830)(C:\Users\hasee\Desktop\XIKAIJAVA\mybatis\2\1596677183228.png)]
由此可看出当Java实体类的属性名与数据库字段名不一致时,查询出来的结果为空
select * from user 等价于 select id,name,pwd from user;
mybatis会根据数据库的字段名去找对应的实体类的属性名,(他会将所有列名转换为小写,然后去找实体类中对应的 set方法 ,set方法后面的字段就对应数据库的字段名;如果不一样就会返回null)
**方法一:**修改set方法名称【不推荐使用】
public void setPwd(String password) {
this.password = password;
}
修改后查询结果即可查询出pwd字段
**方法二:**给sql语句取别名【字段少的时候推荐使用】
<select id="getUser" resultType="User">
select id, name, pwd as password from user;
select>
**方法三:**结果集映射ResultMap 【最推荐的方式】
<mapper namespace="org.westos.dao.UserMapper">
<select id="getUser" resultMap="Users">
select * from user;
select>
<resultMap id="Users" type="User">
<id column="id" property="id"/>
<result column="name" property="name"/>
<result column="pwd" property="password"/>
resultMap>
mapper>
Log4j依赖
<dependency>
<groupId>log4jgroupId>
<artifactId>log4jartifactId>
<version>1.2.17version>
dependency>
log4j的配置文件
### Log4j配置 ###
#定义log4j的输出级别和输出目的地(目的地可以自定义名称,和后面的对应)
#[ level ] , appenderName1 , appenderName2
log4j.rootLogger=DEBUG,console,file
#-----------------------------------#
#1 定义日志输出目的地为控制台
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
####可以灵活地指定日志输出格式,下面一行是指定具体的格式 ###
#%c: 输出日志信息所属的类目,通常就是所在类的全名
#%m: 输出代码中指定的消息,产生的日志具体信息
#%n: 输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"输出日志信息换行
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=[%c]-%m%n
#-----------------------------------#
#2 文件大小到达指定尺寸的时候产生一个新的文件
log4j.appender.file = org.apache.log4j.RollingFileAppender
#日志文件输出目录
log4j.appender.file.File=log/info.log
#定义文件最大大小
log4j.appender.file.MaxFileSize=10mb
###输出日志信息###
#最低级别
log4j.appender.file.Threshold=ERROR
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%p][%d{yy-MM-dd}][%c]%m%n
#-----------------------------------#
#3 druid
log4j.logger.druid.sql=INFO
log4j.logger.druid.sql.DataSource=info
log4j.logger.druid.sql.Connection=info
log4j.logger.druid.sql.Statement=info
log4j.logger.druid.sql.ResultSet=info
#4 mybatis 显示SQL语句部分
log4j.logger.org.mybatis=DEBUG
#log4j.logger.cn.tibet.cas.dao=DEBUG
#log4j.logger.org.mybatis.common.jdbc.SimpleDataSource=DEBUG
#log4j.logger.org.mybatis.common.jdbc.ScriptRunner=DEBUG
#log4j.logger.org.mybatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG
#log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.ResultSet=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
在Mybatis的核心配置文件中进行配置
<settings>
<setting name="logImpl" value="LOG4J"/>
settings>
另外,若只需要Mybatis的默认日志,则只需要以下配置:
<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
settings>
atis的核心配置文件中进行配置**
<settings>
<setting name="logImpl" value="LOG4J"/>
settings>
另外,若只需要Mybatis的默认日志,则只需要以下配置:
<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
settings>