5、resuletMap解决属性名与字段名不一致的问题

数据库中的字段
![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>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值