Spring Boot——MyBatis配置带下划线命名的字段自动转换驼峰命名解决方案

问题描述

MyBatis无法查询出属性名和数据库字段名不完全相同的数据。

即:属性名和数据库字段名分别为驼峰命名下划线命名时查出的数据为NULL

问题分析

MyBatis默认是属性名和数据库字段名一一对应的,即 

数据库表列:user_name 

实体类属性:user_name

但是java中一般使用驼峰命名 

数据库表列:user_name 

实体类属性:userName

解决方案

Spring Boot中,可以通过设置map-underscore-to-camel-case属性为true来开启驼峰功能。  

MyBatis配置: 

application.properties中: 

#开启驼峰命名转换
mybatis.configuration.map-underscore-to-camel-case=true

application.yml中: 

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);

查出来的结果,会被自动转换成phoneNumcardNum,再和结果类(这里就是User )中的属性进行匹配。 

教学视频

DEBUG过程【大概40分钟以后】:https://www.bilibili.com/video/av65117012/?p=23

参考文章

https://segmentfault.com/a/1190000010240142 

https://www.cnblogs.com/leeego-123/p/10725012.html

https://blog.csdn.net/weixin_41758407/article/details/90722718

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Starzkg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值