数据库中的字段
![image.png](https://img-blog.csdnimg.cn/img_convert/6c49d9923de721ae4c544ea4305c32ca.png#clientId=ud538ea37-b529-4&from=paste&height=295&id=u22d0e6c5&margin=[object Object]&name=image.png&originHeight=360&originWidth=278&originalType=binary&ratio=1&size=14843&status=done&style=none&taskId=u7c0c0a5f-d6f9-4d8d-8fd8-d627dda4d14&width=228)
新建一个项目, 拷贝之前的, 测试实体类属性与数据库表中字段不一致的情况
数据库字段: id、name、pwd
实体类属性: id、name、password
5.1、出现问题:
![image.png](https://img-blog.csdnimg.cn/img_convert/7071b1efabe060c4dae32ae65026f1b4.png#clientId=u4161774c-d434-4&from=paste&height=103&id=u22dcea97&margin=[object Object]&name=image.png&originHeight=113&originWidth=643&originalType=binary&ratio=1&size=14357&status=done&style=shadow&taskId=ufcf896bd-65b9-450f-8093-4563fc7dd18&width=588.5)
主要原因:
sql语句无法识别
select * from mybatis.user where id
= #{id}
等价于
select id,name,pwd from mybatis.user where id
= #{id}
解决方法:
①sql语句中起别名
select id,name,pwd as password from mybatis.user where id
= #{id}
②结果集映射(resultMap) (推荐)
<?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=绑定一个对应的Dao/Mapper接口-->
<mapper namespace="com.dao.UserMapper">
<!--结果集映射-->
<resultMap id="UserMap" type="User">
<!--column: 数据库中的字段 property: 实体类中的属性-->
<result column="id" property="id"/>
<result column="name" property="name"/>
<result column="pwd" property="password"/>
</resultMap>
<!--通过ID查询用户-->
<select id="getUserById" parameterType="int" resultMap="UserMap">
select *
from mybatis.user
where `id` = #{id}
</select>
</mapper>
5.2、resultMap的简单映射
resultMap 元素是 MyBatis 中最重要最强大的元素。
ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。
然后在引用它的语句中设置 resultMap 属性就行了(去掉了 resultType 属性)。
<?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=绑定一个对应的Dao/Mapper接口-->
<mapper namespace="com.dao.UserMapper">
<!--结果集映射-->
<resultMap id="UserMap" type="User">
<!--column: 数据库中的字段 property: 实体类中的属性-->
<result column="id" property="id"/>
<result column="name" property="name"/>
<result column="pwd" property="password"/>
</resultMap>
<!--通过ID查询用户-->
<select id="getUserById" parameterType="int" resultMap="UserMap">
select *
from mybatis.user
where `id` = #{id}
</select>
</mapper>