实体类中的属性名和表中的字段名不一样,怎么办?

Posted 永旗狍子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实体类中的属性名和表中的字段名不一样,怎么办?相关的知识,希望对你有一定的参考价值。

我们使用idea通过右上角Database可以将数据库中的数据直接导入,点击此处有教程。

通过上面快速导入的方法idea会把mgr_id,mgr_name该字段,转变为mgrId,mgrName字段,保存在我们的entity(实体类)中。

解决:MyBatis自动ORM失效

原因:MyBatis只能自动维护库表”列名“与”属性名“相同时的一一对应关系,二者不同时,无法自动ORM。

方法一:取别名

通过在查询的 sql 语句中定义字段名的别名,让字段名的别名和实体类 的属性名一致。

<mapper namespace="com.cos.mybatis.ManagerDao">
    <select id="selectManagerByIdAndPwd" resultType="com.qf.mybatis.part2.orm.Manager">
        SELECT mgr_id AS id , mgr_name AS username , mgr_pwd AS password
        FROM t_managers
        WHERE mgr_id = #{id} AND mgr_pwd = #{pwd}
    </select>
</mapper>

方法二:结果映射(ResultMap - 查询结果的封装规则)

通过< resultMap id="" type="" >映射,匹配列名与属性名。

<mapper namespace="com.cos.mybatis.ManagerDao">

    <!--定义resultMap标签-->
    <resultMap id="managerResultMap" type="com.cos.mybatis.Manager">
      	<!--关联主键与列名-->
        <id property="id" column="mgr_id" />
      
      	<!--关联属性与列名-->
        <result property="username" column="mgr_name" />
        <result property="password" column="mgr_pwd" />
    </resultMap>
  
     <!--使用resultMap作为ORM映射依据-->
    <select id="selectAllManagers" resultMap="managerResultMap">
        SELECT mgr_id , mgr_name , mgr_pwd
        FROM t_managers
    </select>
</mapper>

 

以上是关于实体类中的属性名和表中的字段名不一样,怎么办?的主要内容,如果未能解决你的问题,请参考以下文章

Java面试宝典每日3题:day26

mybatis

Mybatis重点总结+常见面试

mybitis中对象字段与表中字段名称不匹配(复制)

Mybatis 的常见面试题

mybatis基于注解的sql语句,bean的属性名和表的字段名不一样怎么办?