Mybatis resultType返回結(jié)果為null的問題排查方式
resultType返回結(jié)果為null的問題
sql語(yǔ)句大致如下
? <select id="findFinancialProductConfigList" resultType="com.xxx.FinancialProductConfigDTO"> ? ? select ?<include refid="Base_Column_List" /> ? ? from fsc_xxx ? ? <where> ? ? ...... ? ? <where>
resultType返回的FinancialProductConfigDTO類,屬性名稱都是以駝峰形式命名的,比如financialProductConfigId;而對(duì)應(yīng)的數(shù)據(jù)庫(kù)表里面的字段都是下劃線形式的,如financial_product_config_id。
結(jié)果發(fā)現(xiàn),返回的結(jié)果都是null,打印了SQL,確實(shí)查到了記錄,因此判定是結(jié)果集和返回類型的字段映射問題。
之前一直以為Mybatis會(huì)自動(dòng)把數(shù)據(jù)庫(kù)下劃線字段轉(zhuǎn)換成POJO類(resultType對(duì)應(yīng)的類)的駝峰屬性字段,但是發(fā)現(xiàn)是自己記錯(cuò)了,這個(gè)Mybatis默認(rèn)不會(huì)自動(dòng)轉(zhuǎn)換,所以返回結(jié)果為null,特此記錄。
解決辦法有下面幾種
1、select 字段時(shí),給數(shù)據(jù)庫(kù)下劃線字段加別名,改成對(duì)應(yīng)的類駝峰屬性字段,例如:
select financial_product_config_id as financialProductConfigId
2、不用resultType了,改用resultMap把下劃線字段和駝峰字段對(duì)應(yīng)上;
3、啟用Mybatis的mapUnderscoreToCamelCase為true,這樣就可以實(shí)現(xiàn)數(shù)據(jù)庫(kù)下劃線字段到POJO類駝峰形式的自動(dòng)映射了。
resultType獲取結(jié)果一些有值一些為null
前提使用框架:spring boot
原因
沒有配置mybatis駝峰命名規(guī)則且使用的是返回的結(jié)果類型為resultType
配置如下
bean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
@Bean(name = "sqlSessionFactory")
?? ?public SqlSessionFactory sqlSessionFactoryBean(@Qualifier("datasource") DataSource datasource) {
?? ??? ?SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
?? ??? ?try {?? ??? ?
?? ??? ?bean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
?? ??? ??? ?return bean.getObject();
?? ??? ?} catch (Exception e) {
?? ??? ??? ?e.printStackTrace();
?? ??? ??? ?throw new RuntimeException(e);
?? ??? ?}
?? ?}以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot+WebSocket+Netty實(shí)現(xiàn)消息推送的示例代碼
這篇文章主要介紹了SpringBoot+WebSocket+Netty實(shí)現(xiàn)消息推送的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
java socket長(zhǎng)連接中解決read阻塞的3個(gè)辦法
這篇文章主要介紹了java socket長(zhǎng)連接中解決read阻塞的3個(gè)辦法,本文取了折中的一個(gè)方法,并給出代碼實(shí)例,需要的朋友可以參考下2014-08-08
@Transaction,@Async在同一個(gè)類中注解失效的原因分析及解決
這篇文章主要介紹了@Transaction,@Async在同一個(gè)類中注解失效的原因分析及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
通過(guò)實(shí)例學(xué)習(xí)Spring @Required注釋原理
這篇文章主要介紹了通過(guò)實(shí)例學(xué)習(xí)Spring @Required注釋原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
eclipse創(chuàng)建java項(xiàng)目并運(yùn)行的詳細(xì)教程講解
eclipse是java開發(fā)的ide工具,是大部分java開發(fā)人員的首選開發(fā)工具,可是對(duì)于一些新Java人員來(lái)說(shuō),不清楚eclipse怎么運(yùn)行項(xiàng)目?這篇文章主要給大家介紹了關(guān)于eclipse創(chuàng)建java項(xiàng)目并運(yùn)行的相關(guān)資料,需要的朋友可以參考下2023-04-04

