• 使用全局配置处理字段名和属性名不一致的情况


    使用全局配置处理字段名和属性名不一致的情况

    • 若字段名和实体类中的属性名不一致,但是字段名符合数据库的规则(使用_),实体类中的属性名符合Java的规则(使用驼峰)

    此时可通过以下三种方式处理字段名和实体类中的属性的映射关系

    • a>可以通过为字段起别名的方式,保证和实体类中的属性名保持一致
    • b>可以在MyBatis的核心配置文件中设置一个全局配置信息mapUnderscoreToCamelCase,可以在查询表中数据时,自动将_类型的字段名转换为驼峰
    • 使用resultMap
    例如:字段名user_name,设置了mapUnderscoreToCamelCase,此时字段名就会转换为
    userName

    MyBatis的核心配置文件 mybatis-config.xml

    1. "1.0" encoding="UTF-8" ?>
    2. configuration
    3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    4. "https://mybatis.org/dtd/mybatis-3-config.dtd">
    5. <configuration>
    6. <properties resource="jdbc.properties"/>
    7. <settings>
    8. <setting name="mapUnderscoreToCamelCase" value="true"/>
    9. settings>
    10. <typeAliases>
    11. <package name="com.atguigu.mybatis.pojo"/>
    12. typeAliases>
    13. <environments default="development">
    14. <environment id="development">
    15. <transactionManager type="JDBC"/>
    16. <dataSource type="POOLED">
    17. <property name="driver" value="${jdbc.driver}"/>
    18. <property name="url" value="${jdbc.url}"/>
    19. <property name="username" value="${jdbc.username}"/>
    20. <property name="password" value="${jdbc.password}"/>
    21. dataSource>
    22. environment>
    23. environments>
    24. <mappers>
    25. <package name="com.atguigu.mybatis.mapper"/>
    26. mappers>
    27. configuration>

    EmpMapper 接口

    1. public interface EmpMapper {
    2. /**
    3. * 根据id查询员工信息
    4. * @param empId
    5. * @return
    6. */
    7. Emp getEmpByEmpId(@Param("empId") Integer empId);
    8. }

    MyBatis的映射文件 EmpMapper.xml

    1. "1.0" encoding="UTF-8" ?>
    2. mapper
    3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    4. "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
    5. <mapper namespace="com.atguigu.mybatis.mapper.EmpMapper">
    6. <select id="getEmpByEmpId" resultType="Emp">
    7. select * from t_emp where emp_id = #{empId}
    8. select>
    9. mapper>

    测试

    1. public class ResultMapTest {
    2. @Test
    3. public void testGetEmpByEmpId(){
    4. SqlSession sqlSession = SqlSessionUtil.getSqlSession();
    5. EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
    6. Emp emp = mapper.getEmpByEmpId(1);
    7. System.out.println(emp);
    8. }
    9. }

  • 相关阅读:
    C++虚函数指针(virtual)
    阅读笔记——A Frustratingly Easy Approach for Entity and Relation Extraction
    stm32 Keil V5 开发pack突然丢失
    【jquery Ajax 】art-template模板引擎的概念与使用
    SAP CO系统配置-获利能力分析
    华为防火墙基础自学系列 | Hub Spoke IPsec VdPdNd
    python资源库
    关于企业微信的第三方应用开发vue3开发
    lnmp环境部署
    八股文第十一天
  • 原文地址:https://blog.csdn.net/weixin_52385232/article/details/127558272