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

 更新时间:2023年01月15日 10:01:03   作者:zjw_rp  
本文主要介绍了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>

到此这篇关于MyBatis字段名和属性名不一致的解决方法的文章就介绍到这了,更多相关MyBatis字段名和属性名不一致内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java logback日志的简单使用

    Java logback日志的简单使用

    这篇文章主要介绍了Java logback日志的使用详解,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下
    2021-03-03
  • springboot启动feign项目报错:Service id not legal hostnam的解决

    springboot启动feign项目报错:Service id not legal hostnam的解决

    这篇文章主要介绍了springboot启动feign项目报错:Service id not legal hostnam的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • 如何使用新方式编写Spring MVC接口

    如何使用新方式编写Spring MVC接口

    这篇文章主要介绍了如何使用新方式编写Spring MVC接口,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • spring中@Bean和@Component的区别及说明

    spring中@Bean和@Component的区别及说明

    文章主要介绍了@Bean和@Component两个注解在Spring框架中的定义、作用范围、创建方式、扫描和识别机制以及使用场景和建议
    2024-12-12
  • IDEA配置SpringBoot热启动,以及热启动失效问题

    IDEA配置SpringBoot热启动,以及热启动失效问题

    这篇文章主要介绍了IDEA配置SpringBoot热启动,以及热启动失效问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Java实现五子棋游戏

    Java实现五子棋游戏

    这篇文章主要为大家详细介绍了Java实现五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • java根据模板导出PDF的详细实现过程

    java根据模板导出PDF的详细实现过程

    前段时间因为相关业务需求需要后台生成pdf文件,所以下面这篇文章主要给大家介绍了关于java根据模板导出PDF的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-02-02
  • Java利用钉钉机器人实现发送群消息

    Java利用钉钉机器人实现发送群消息

    这篇文章主要为大家详细介绍了Java语言如何通过钉钉机器人发送群消息通知,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2022-09-09
  • SpringBoot bean依赖属性配置详细介绍

    SpringBoot bean依赖属性配置详细介绍

    Spring容器是Spring的核心,一切SpringBean都存储在Spring容器内。可以说bean是spring核心中的核心。Bean配置信息定义了Bean的实现及依赖关系,这篇文章主要介绍了SpringBoot bean依赖属性配置
    2022-09-09
  • SpringBoot2.x版本中,使用SpringSession踩的坑及解决

    SpringBoot2.x版本中,使用SpringSession踩的坑及解决

    这篇文章主要介绍了SpringBoot2.x版本中,使用SpringSession踩的坑及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07

最新评论