mybatis提供了一个配置:
#开启驼峰命名转换
mybatis.configuration.map-underscore-to-camel-case=true
使用该配置可以让mybatis自动将SQL中查出来的带下划线的字段,转换为驼峰标志,再去匹配类中的属性。
即:
@Select("select phone_num,card_num from xxx where id=#{id}") public User getUserInfo(String id);
查出来的结果,会被自动转换成phonenum和cardnum,再和结果类(这里就是User )中的属性进行匹配。
更多和自动转换驼峰标志相关的详细源码分析可以参考:传送门
————————————————————分割线—————————————————
下面我们说说我这次碰到的奇怪问题:
在我的项目中,明明在application.properties中将这个属性设为了true,结果运行到上文截图57行代码时始终为false,导致后边无法找到匹配的属性。
经过一番DEBUG分析,发现项目为了做多数据源,将生成
org.apache.ibatis.session.SqlSessionFactory
的配置抽出到使用@Configuration修饰的配置类中。
application.properties配置文件中关于驼峰转换的配置内容没有放进去。这些错误的代码我就不在这贴了,直接上改善后的代码:
经过调整之后变成了以下形式:
将application.properties mybatis的congfig加载到类中,再注入到SqlSessionFactoryBean中,问题解决。