MyBatis入门(五)---解决字段名与实体类属性名不相同的冲突

在平时的开发中,我们表中的字段名和表对应实体类的属性名称不一定都是完全相同的,下面来演示一下这种情况下的如何解决字段名与实体类属性名不相同的冲突。

一、准备演示需要使用的表和数据

create database mybatis;
use mybatis;
CREATE TABLE User(
    u_id INT PRIMARY KEY AUTO_INCREMENT,
    u_name VARCHAR(20), 
    u_age INT
);
INSERT INTO User(u_name, u_age) VALUES('Zhangsan', 23);
INSERT INTO User(u_name, u_age) VALUES('Lisi', 20);
INSERT INTO User(u_name, u_age) VALUES('Wangwu', 22);


mysql> select * from User;
+------+----------+-------+
| u_id | u_name   | u_age |
+------+----------+-------+
|    1 | Zhangsan |    23 |
|    2 | Lisi     |    20 |
|    3 | Wangwu   |    22 |
+------+----------+-------+

二、定义实体类

package me.mybatis.entity;

/**
 * User 表所对应的实体类
 */
public class User {
    //实体类的属性和表的字段名称一一对应
    private int id;
    private String name;
    private int age;

    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 int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
    }
}

三、定义接口

package me.mybatis.dao;

import me.mybatis.entity.User;

public interface IUser {
    public User getUserById(int id);

    public User selectUser(int id);

    public User selectUserResultMap(int id);
}

四、SQL映射文件

<?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必须是IUser的路径-->
<mapper namespace="me.mybatis.dao.IUser">
    <!--
     根据id查询得到一个User对象,使用这个查询是查询不到我们想要的结果的,
     这主要是因为实体类的属性名和数据库的字段名对应不上的原因,因此无法查询出对应的记录
    -->
    <select id="getUserById" parameterType="int" resultType="_User">
        SELECT * FROM User WHERE id=#{id}
    </select>

    <!--
      根据id查询得到一个User对象,使用这个查询是可以正常查询到我们想要的结果的,
      这是因为我们将查询的字段名都起一个和实体类属性名相同的别名,这样实体类的属性名和查询结果中的字段名就可以一一对应上
    -->
    <select id="selectUser" parameterType="int" resultType="_User">
        SELECT u_id id, u_name name, u_age age from User
        where u_id = #{id}
    </select>

    <!--
    根据id查询得到一个User对象,使用这个查询是可以正常查询到我们想要的结果的,
    这是因为我们通过<resultMap>映射实体类属性名和表的字段名一一对应关系
    -->
    <select id="selectUserResultMap" parameterType="int" resultMap="userResultMap">
        select * from User where u_id = #{id}
    </select>
    <!--通过<resultMap>映射实体类属性名和表的字段名对应关系 -->
    <resultMap id="userResultMap" type="me.mybatis.entity.User">
        <!-- 用id属性来映射主键字段 -->
        <id property="id" column="u_id" />
        <!-- 用result属性来映射非主键字段 -->
        <result property="name" column="u_name"/>
        <result property="age" column="u_age"/>
    </resultMap>

</mapper>

五、编写测试

package me.mybatis.test;

import me.mybatis.dao.IUser;
import me.mybatis.entity.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.Reader;

public class UserTest {

    private static SqlSessionFactory sqlSessionFactory;
    private static Reader reader;

    static {
        try {
            String resource = "mybatis-config.xml";
            reader = Resources.getResourceAsReader(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {
//        getUserById();
//        selectUser();
        selectUserResultMap();
    }


    private static void getUserById() {
        SqlSession session = sqlSessionFactory.openSession();
        IUser iUser = session.getMapper(IUser.class);
        User user = iUser.getUserById(1);
        System.out.println(user);
        session.close();
    }

    private static void selectUser() {
        SqlSession session = sqlSessionFactory.openSession();
        IUser iUser = session.getMapper(IUser.class);
        User user = iUser.selectUser(1);
        System.out.println(user);
        session.close();
    }

    private static void selectUserResultMap() {
        SqlSession session = sqlSessionFactory.openSession();
        IUser iUser = session.getMapper(IUser.class);
        User user = iUser.selectUserResultMap(1);
        System.out.println(user);
        session.close();
    }
}

执行单测试的结果:

1、getUserById方法执行查询不到结果。

2、selectUser方法和selectUserResultMap方法执行查询后可以正常得到想要的结果

六、总结

上面的测试代码演示当实体类中的属性名和表中的字段名不一致时,使用MyBatis进行查询操作时无法查询出相应的结果的问题以及针对问题采用的两种办法:

解决办法一:

通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致,这样就可以表的字段名和实体类的属性名一一对应上了,这种方式是通过在sql语句中定义别名来解决字段名和属性名的映射关系的。

解决办法二:

通过<resultMap>来映射字段名和实体类属性名的一一对应关系。这种方式是使用MyBatis提供的解决方式来解决字段名和属性名的映射关系的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大数据AI

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值