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


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

    • 若字段名和实体类中的属性名不一致,但是字段名符合数据库的规则(使用_),实体类中的属性名符合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. }

  • 相关阅读:
    优思学院|精益六西格玛领导者必学 10 个管理技巧
    网站备案注销(删除),域名备案注销(删除),备案怎么注销删除
    php水果百科动态网站毕业设计-附源码060917
    mysql8压缩包安装
    vue3+ts+vant移动端H5项目搭建
    对话ACE第五期:到底什么才是真正的HTAP?
    【学习笔记】AGC018
    业务开发时,接口不能对外暴露的解决方案
    【BurpSuite】插件开发学习之J2EEScan(下)-主动扫描(31-40)
    4.2 Hive SQL
  • 原文地址:https://blog.csdn.net/weixin_52385232/article/details/127558272