开发者

mybatisplus下划线驼峰转换的问题解决

开发者 https://www.devze.com 2024-10-31 10:24 出处:网络 作者: Echoo华地
目录问题儿:对象中包含下划线js的字段儿查询不出来问题儿:对象中包含下划线的字段儿查询不出来
目录
  • 问题儿:对象中包含下划线js的字段儿查询不出来

问题儿:对象中包含下划线的字段儿查询不出来

myBATis-plus中,默认开启了下滑线-驼峰转换

会把数据库字段中的下划线自动转换成驼峰形式,然后去匹配实体类对象的字段

online_num -> onlineNum

如果在一个实体类中存php在一个带下划线的字段,查询出来为null

 private Integer online_num;

即使用了@TableField()注解去指定映射关系,查询结果也为null

 @TableField("online_num")
 private Integer online_num;

问题就是出现在了驼峰转换这里,因为已经指明了映射关系,所以把驼峰转换关掉就行:

yml:

mybatis-plus:
  configuration:
    map-underscore-to-camel-case: false

properties:

mybatis-plus.configuration.map-undersc编程客栈ore-to-caVCDfKmel-case=false

但是这里有个问题,你关了自动驼峰转换,所有字段都要通过@TableField()注解去指定映射关系或者在mapper.XML中指定映射关系,这样增加了很多工作量。所以非必要情况下类字段还是不要用_去命名字段,省得麻烦。

实在不行,如果一定要用下划线字段,看看具体的原因是什么:

①如果是序列化或者反序列话需要的话,可以用@jsonProperty和@JsonAlias来解决

②如果是toString需要,那就重写一下Object的toString方法

③其他情况的话,可以加一个字段比如a_b,就加一个aB字段,然后手写一下a_b字段对应的getter,setter,使它们指向aB字段,如果不想转字段就转对象,查询用一个对www.devze.com象,然后对业务一个对象,查询出来后就转成业务对象,奇技淫巧还是很多滴~

到此这篇关于mybatisplus下划线驼峰转换的问题解决的文章就介绍到这了,更多相关mybatisplus下划线驼峰转换内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号