使用全局配置处理字段名和属性名不一致的情况
- 若字段名和实体类中的属性名不一致,但是字段名符合数据库的规则(使用_),实体类中的属性名符合Java的规则(使用驼峰)
此时可通过以下三种方式处理字段名和实体类中的属性的映射关系
- a>可以通过为字段起别名的方式,保证和实体类中的属性名保持一致
- b>可以在MyBatis的核心配置文件中设置一个全局配置信息mapUnderscoreToCamelCase,可以在查询表中数据时,自动将_类型的字段名转换为驼峰
- 使用resultMap
例如:字段名user_name,设置了mapUnderscoreToCamelCase,此时字段名就会转换为
userName


MyBatis的核心配置文件 mybatis-config.xml
"1.0" encoding="UTF-8" ?>
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-config.dtd">
<properties resource="jdbc.properties"/>
<setting name="mapUnderscoreToCamelCase" value="true"/>
<package name="com.atguigu.mybatis.pojo"/>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<package name="com.atguigu.mybatis.mapper"/>
EmpMapper 接口
public interface EmpMapper {
Emp getEmpByEmpId(@Param("empId") Integer empId);
MyBatis的映射文件 EmpMapper.xml
"1.0" encoding="UTF-8" ?>
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.atguigu.mybatis.mapper.EmpMapper">
<select id="getEmpByEmpId" resultType="Emp">
select * from t_emp where emp_id = #{empId}
测试
public class ResultMapTest {
public void testGetEmpByEmpId(){
SqlSession sqlSession = SqlSessionUtil.getSqlSession();
EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
Emp emp = mapper.getEmpByEmpId(1);
