Zhiyuu 2022-06-28 11:02 采纳率: 100%
浏览 431
已结题

MyBatis驼峰映射失效

问题遇到的现象和发生背景

今天在学MyBatis的时候发现自己设置的驼峰映射不起作用了,User类 的命名都是驼峰法,数据库都是下划线连接的,但是查询的时候无法正确的返回映射回来的User对象

问题相关代码,请勿粘贴截图

这是测试类的代码

public class UserMapperTest {

    UserMapper userMapper = null;
    SqlSession sqlSession = null;
    @Before
    public void setUp() throws Exception {
        //1.获取核心配置文件
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        //2.创建sqlSessionFactory工厂对象
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        //3.创建sqlSession对象
        sqlSession = sqlSessionFactory.openSession();
        //获取接口的动态代理对象
        userMapper = sqlSession.getMapper(UserMapper.class);
    }

    @Test
    public void findById() {
        User user = userMapper.findById(2);
        System.out.println("用户ID" + user.getUserId());
        System.out.println("用户名" + user.getUserName());
        System.out.println("用户年龄" + user.getUserAge());
        sqlSession.close();
    }
}

映射文件的查询部分

<select id="findById"
            parameterType="int"
            resultType="user">
        select *
        from users
        where user_id=#{userId}
</select>

核心配置文件驼峰映射已经开了

<settings>
        <!--开启驼峰映射-->
        <setting name="mapUnderscoreToCamelCase" value="ture"/>
</settings>

运行结果及报错内容

查询时直接报了空指针异常

img

我的解答思路和尝试过的方法

尝试过把其中两项属性改成一样的命名,一样的命名的值就可以正确返回,不一致的就无法返回,但设置了驼峰映射后不应该会自动匹配上吗

我想要达到的结果
  • 写回答

3条回答 默认 最新

  • 微笑精灵 2022-06-28 13:10
    关注

    true
    不是ture

        <setting name="mapUnderscoreToCamelCase" value="ture"/>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 7月6日
  • 已采纳回答 6月28日
  • 创建了问题 6月28日

悬赏问题

  • ¥15 springboot接入微信支付SDK
  • ¥50 大区域的遥感影像匹配 怎么做啊
  • ¥15 求解答:pytorch跑yolov8神经网络受挫
  • ¥20 Js代码报错问题不知道怎么解决
  • ¥15 gojs 点击按钮node的position位置进行改变,再次点击回到原来的位置
  • ¥15 计算决策面并仿真附上结果
  • ¥20 halcon 图像拼接
  • ¥15 webstorm上开发的vue3+vite5+typeScript打包时报错
  • ¥15 vue使用gojs,需求在link中的虚线上添加方向箭头
  • ¥15 CSS通配符清除内外边距为什么可以覆盖默认样式?