日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

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

發(fā)布時間:2025/3/21 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatis支持驼峰自动转换sql吗_mybatis-plus返回map自动转驼峰配置操作 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

mybatis-plus返回map自動轉(zhuǎn)駝峰配置object-wrapper-factory不生效問題解決;配置map-underscore-to-camel-case: true不生效問題解決

很多時候我們工作中查詢很多字段的時候一般是返回一個VO來接收,這個時候我們只要在yml中配置了

map-underscore-to-camel-case: true

就會自動將查詢數(shù)據(jù)庫的字段帶下劃線的屬性轉(zhuǎn)成對應(yīng)實體類VO中駝峰命名的屬性。

但是會經(jīng)常有這種場景:例如我們只查詢2個字段要返回給前端,這時候我們還需要新建一個VO,很是麻煩,我們只需要查詢返回一個Map來接收就可以了 ,但是返回到控制臺的屬性結(jié)果卻不是駝峰命名。

如下圖 ,這就是為何你yml中配置了map-underscore-to-camel-case: true也不生效的原因。(對返回map不生效

怎么解決這個問題呢?解決方案:

mybatis-plus其實已經(jīng)幫我們寫好了MybatisMapWrapperFactory類(開啟返回map結(jié)果集的下劃線轉(zhuǎn)駝峰)

在mybatis-plus-extension.jar下有一個類

com.baomidou.mybatisplus.extension.MybatisMapWrapperFactory

com.baomidou.mybatisplus.extension.handlers.MybatisMapWrapper

mybatis-plus自帶map下劃線轉(zhuǎn)駝峰配置類

重點:

我們只需要在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轉(zhuǎn)化為ObjectWrapperFactory對象。這又是什么鬼呢?

看字面意思,應(yīng)該是缺少對應(yīng)的converter,難道m(xù)ybatis沒有提供這個converter嗎?

簡直有點坑。而且springboot也不提供用反射機制來構(gòu)件對象的converter?

是的,springboot沒有這樣做。通過查資料得知springboot提供了一種擴展機制,允許你來寫一個converter來完成你想要的轉(zhuǎn)換工作。于是,我又寫了一個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不報錯了,這時候來看看結(jié)果是不是返回map自動轉(zhuǎn)成駝峰命名。果然自動轉(zhuǎn)了

返回map自動轉(zhuǎn)駝峰命名

第二種方式:如果嫌配置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時多表聯(lián)查,返回map的時候,發(fā)現(xiàn)map里面的value是空的情況下

字段也不顯示了 導致頁面取值報錯,如下圖

上網(wǎng)查了一下,在yml文件中加入一個配置就可以了

mybatis:

configuration:

call-setters-on-nulls: true

以上這篇mybatis-plus返回map自動轉(zhuǎn)駝峰配置操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持我們。

時間: 2020-11-25

總結(jié)

以上是生活随笔為你收集整理的mybatis支持驼峰自动转换sql吗_mybatis-plus返回map自动转驼峰配置操作的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。