解决属性名和字段名不一致的问题

1、 问题

数据库中的字段
在这里插入图片描述
测试实体类字段不一致的情况

public class User {
    
    private int id;
    private String name;
    private String password;
}

测试出现问题
在这里插入图片描述
分析SQL:

//    select * from mybatis.user where id = #{id}
//类型处理器
//    select id,name,pwd from mybatis.user where id = #{id}

解决方法:

  • 起别名
<select id="getUserById" resultType="com.kuang.pojo.User">
    select id,name,pwd as password from mybatis.user where id = #{id}
</select>

2、resultMap

结果集映射

id   name   pwd
id   name   password
<!--结果集映射-->
<resultMap id="UserMap" type="User">
    <!--column数据库中的字段,property实体类中的属性-->
    <result column="id" property="id"/>
    <result column="name" property="name"/>
    <result column="pwd" property="password"/>
</resultMap>

<select id="getUserById" resultMap="UserMap">
    select * from mybatis.user where id = #{id}
</select>
  • resultMap 元素是 MyBatis 中最重要最强大的元素
  • ResultMap 的设计思想是,对于简单的语句根本不需要配置显式的结果映射,而对于复杂一点的语句只需要描述它们的关系就行了。
  • ResultMap 最优秀的地方在于,虽然你已经对它相当了解了,但是根本就不需要显式地用到他们。
  • 如果世界总是这么简单就好了☺。
发布了13 篇原创文章 · 获赞 9 · 访问量 183

猜你喜欢

转载自blog.csdn.net/qq_46921028/article/details/105555544