Mybatis学习笔记(三):解决实体类属性和数据库字段名不一致

一、Mybatis解决实体类属性和数据库字段名不一致

案例:在user表中查询所有字段

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实现

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>

你可能感兴趣的:(mybatis,mybatis,数据库,java,mysql)