您的当前位置:首页mybatis设置驼峰映射后失效问题(多数据源)

mybatis设置驼峰映射后失效问题(多数据源)

来源:锐游网

前言

按照通用策略yml配置驼峰失效 😦

mybatis:
  configuration:
    # 启动结果集自动映射  NONE 表示取消自动映射;PARTIAL 只会自动映射没有定义嵌套结果集映射的结果集。 FULL 会自动映射任意复杂的结果集(无论是否嵌套)。默认是partial,这是一种全局设置
    auto-mapping-behavior: partial
    # 开启驼峰映射
    mapUnderscoreToCamelCase: true

注:此配置只适用与单数据源,如果单数据源驼峰失效,大多数配置问题,这方面找答案
数据库:user_name ==> 驼峰 userName

问题

因为我是多数据源链接,使用了自定义的配置数据源工具类,和原有单数据源内部扫描逻辑不同。也就是我虽然配置了全局驼峰,但是单个数据源并不会加载配置

尝试

网上找到了第一种解决方式,手动注入mybatis.configuration 很遗憾 尝试无效

        @Bean
        @ConfigurationProperties(prefix = "mybatis.configuration")
        public org.apache.ibatis.session.Configuration mybatisConfig(){
            return  new org.apache.ibatis.session.Configuration();
        }

解决

经过再次查找反复修改最终确定另一种注入方式 此方式可以解决多数据源驼峰失效问题

        @Bean(name = "sqlSessionFactory1")
        @Primary
        public SqlSessionFactory sqlSessionFactory1() throws Exception {
            SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
            sqlSessionFactoryBean.setDataSource(ds1);
            //开启驼峰
            org.apache.ibatis.session.Configuration configuration = new org.apache.ibatis.session.Configuration();
            configuration.setMapUnderscoreToCamelCase(true);
            sqlSessionFactoryBean.setConfiguration(configuration);
            return sqlSessionFactoryBean.getObject();
        }

因篇幅问题不能全部显示,请点此查看更多更全内容

Top