日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

mybatis支持驼峰自动转换sql吗_mybatis-plus返回map自动转驼峰配置操作

發布時間:2025/3/21 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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自动转驼峰配置操作的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。