在平时的开发中,我们表中的字段名和表对应实体类的属性名称不一定都是完全相同的,下面来演示一下这种情况下的如何解决字段名与实体类属性名不相同的冲突。
一、准备演示需要使用的表和数据
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提供的解决方式来解决字段名和属性名的映射关系的。