mybatis支持驼峰自动转换sql吗_mybatis-plus返回map自动转驼峰配置操作
mybatis-plus返回map自動轉駝峰配置object-wrapper-factory不生效問題解決;配置map-underscore-to-camel-case: true不生效問題解決
很多時候我們工作中查詢很多字段的時候一般是返回一個VO來接收,這個時候我們只要在yml中配置了
map-underscore-to-camel-case: true
就會自動將查詢數據庫的字段帶下劃線的屬性轉成對應實體類VO中駝峰命名的屬性。
但是會經常有這種場景:例如我們只查詢2個字段要返回給前端,這時候我們還需要新建一個VO,很是麻煩,我們只需要查詢返回一個Map來接收就可以了 ,但是返回到控制臺的屬性結果卻不是駝峰命名。
如下圖 ,這就是為何你yml中配置了map-underscore-to-camel-case: true也不生效的原因。(對返回map不生效
怎么解決這個問題呢?解決方案:
mybatis-plus其實已經幫我們寫好了MybatisMapWrapperFactory類(開啟返回map結果集的下劃線轉駝峰)
在mybatis-plus-extension.jar下有一個類
com.baomidou.mybatisplus.extension.MybatisMapWrapperFactory
和
com.baomidou.mybatisplus.extension.handlers.MybatisMapWrapper
mybatis-plus自帶map下劃線轉駝峰配置類
重點:
我們只需要在yml中配置一下object-wrapper-factory指定MybatisMapWrapperFactory就可以了
mybatis-plus: mapper-locations: classpath:mapper/*Mapper.xml
configuration: call-setters-on-nulls: true
map-underscore-to-camel-case: true
object-wrapper-factory: com.baomidou.mybatisplus.extension.MybatisMapWrapperFactory
然后啟動項目,我去竟然報錯了:
***************************
APPLICATION FAILED TO START
***************************
Description:
Failed to bind properties under 'mybatis-plus.configuration.object-wrapper-factory' to org.apache.ibatis.reflection.wrapper.ObjectWrapperFactory:
Property: mybatis-plus.configuration.object-wrapper-factory
Value: com.baomidou.mybatisplus.extension.MybatisMapWrapperFactory
Origin: class path resource [application.yml]:99:29
Reason: No converter found capable of converting from type [java.lang.String] to type [org.apache.ibatis.reflection.wrapper.ObjectWrapperFactory]
Action:
Update your application's configuration
啟動報錯詳情
提示找不到合適的converter將string轉化為ObjectWrapperFactory對象。這又是什么鬼呢?
看字面意思,應該是缺少對應的converter,難道mybatis沒有提供這個converter嗎?
簡直有點坑。而且springboot也不提供用反射機制來構件對象的converter?
是的,springboot沒有這樣做。通過查資料得知springboot提供了一種擴展機制,允許你來寫一個converter來完成你想要的轉換工作。于是,我又寫了一個converter:
package com.bytedance.douyin.config;
import org.apache.ibatis.reflection.wrapper.ObjectWrapperFactory;
import org.springframework.boot.context.properties.ConfigurationPropertiesBinding;
import org.springframework.core.convert.converter.Converter;
import org.springframework.stereotype.Component;
@Component
@ConfigurationPropertiesBinding
public class ObjectWrapperFactoryConverter implements Converter {
@Override
public ObjectWrapperFactory convert(String source) {
try {
return (ObjectWrapperFactory) Class.forName(source).newInstance();
} catch (InstantiationException | IllegalAccessException | ClassNotFoundException e) {
throw new RuntimeException(e);
}
}
}
再次啟動 ok不報錯了,這時候來看看結果是不是返回map自動轉成駝峰命名。果然自動轉了
返回map自動轉駝峰命名
第二種方式:如果嫌配置Converter麻煩,不自定義Converter,那就不能在yml中配置
object-wrapper-factory: com.baomidou.mybatisplus.extension.MybatisMapWrapperFactory
教你第二種方式:直接這樣配置就搞定了
@Bean
public ConfigurationCustomizer mybatisConfigurationCustomizer(){
return new ConfigurationCustomizer() {
@Override
public void customize(org.apache.ibatis.session.Configuration configuration) {
configuration.setObjectWrapperFactory(new MybatisMapWrapperFactory());
}
};
}
補充知識:解決spring boot整合mybatis時 返回map value為空字段不顯示
這兩天公司從YMP框架換到了spring boot 在整合mybatis時多表聯查,返回map的時候,發現map里面的value是空的情況下
字段也不顯示了 導致頁面取值報錯,如下圖
上網查了一下,在yml文件中加入一個配置就可以了
mybatis:
configuration:
call-setters-on-nulls: true
以上這篇mybatis-plus返回map自動轉駝峰配置操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持我們。
時間: 2020-11-25
總結
以上是生活随笔為你收集整理的mybatis支持驼峰自动转换sql吗_mybatis-plus返回map自动转驼峰配置操作的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python 输出在固定位置_pytho
- 下一篇: 根据经纬度计算范围_遗传算法可视化项目(