admin 管理员组文章数量: 887021
我们使用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>
版权声明:本文标题:实体类中的属性名和表中的字段名不一样,怎么办? 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.freenas.com.cn/jishu/1727373629h1110375.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论