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字段名和属性名不一致内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SpringCloud如何使用Eureka实现服务之间的传递数据
这篇文章主要介绍了SpringCloud使用Eureka实现服务之间的传递数据操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-06-06Spring Boot 整合持久层之JdbcTemplate
持久层是 Java EE 中访问数据库的核心操作,Spring Boot 中对常见的持久层框架都提供了自动化配置,例如 JdbcTemplate 、 JPA 等,Mybatis 的自动化配置则是 Mybatis 官方提供的2022-08-08SpringBoot中使用HTTP客户端工具Retrofit
这篇文章主要为大家介绍了SpringBoot中使用HTTP客户端工具Retrofit方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-06-06
最新评论