软件编程
位置:首页>> 软件编程>> java编程>> MyBatis字段名和属性名不一致的解决方法

MyBatis字段名和属性名不一致的解决方法

作者:zjw_rp  发布时间:2022-12-15 18:15:22 

标签:MyBatis,字段名,属性名

1. 字段取别名,和属性名保持一致

映射文件

<mapper namespace="com.atguigu.mybatis.mapper.EmpMapper">

<!--    字段名跟属性名不一致情况下,如何处理映射关系-->
<!--      Emp getEmpById(@Param("empId") Integer empId);-->
   <select id="getEmpById" resultType="Emp">
<!--方式一:给字段起别名,和属性名保持一致-->
  select  emp_id empId,emp_name empName,age,gender from t_emp where emp_id=#{empId}
   </select>
</mapper>

2. 使用全局配置处理字段名和属性名不一致

当字段符合mysql要求,使用_线,而符合java的要求使用驼峰,

可以在mybatis核心配置设置一个全局配置,可以自动将下划线映射为驼峰。

<setting name="mapUnderscoreToCamelCase" value="true"/>

①核心配置文件

<!--  设置全局配置 将下划线映射为驼峰 -->
<!--emp_id-empId; emp_Name-empName    -->
   <settings>
       <setting name="mapUnderscoreToCamelCase" value="true"/>
   </settings>

②映射文件

<select id="getEmpById" resultType="Emp">
   select * from t_emp where emp_id=#{empId}
   </select>

3. 使用自定义映射resultMap处理字段名和属性不一致情况

resultMap:设置自定义的映射关系

id:唯一标识

type:处理映射关系的实体类的类型

标签:

id:处理主键和实体类中实现的映射关系

result:处理普通字段和实体类中属性的映射关系

column:映射关系中的字段名,必须是sql查询出某个字段

property:设置映射关系中的属性的属性名,必须是处理的实体类类型中的属性名

映射文件

<resultMap id="empResultMap" type="Emp">
       <id column="emp_id" property="empId"></id>
       <result column="emp_name" property="empName"></result>
       <result column="age" property="age"></result>
       <result column="gender" property="gender"></result>
   </resultMap>

<select id="getEmpById" resultMap="empResultMap">
       select * from t_emp where emp_id=#{empId}
   </select>

来源:https://blog.csdn.net/zjw_rp/article/details/128557953

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com