欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis resultType返回結(jié)果為null的問題排查方式

 更新時(shí)間:2022年03月14日 10:42:19   作者:靈穎橋人  
這篇文章主要介紹了Mybatis resultType返回結(jié)果為null的問題排查方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

resultType返回結(jié)果為null的問題

sql語句大致如下

? <select id="findFinancialProductConfigList" resultType="com.xxx.FinancialProductConfigDTO">
? ? select ?<include refid="Base_Column_List" />
? ? from fsc_xxx
? ? <where>
? ? ......
? ? <where>

resultType返回的FinancialProductConfigDTO類,屬性名稱都是以駝峰形式命名的,比如financialProductConfigId;而對應(yīng)的數(shù)據(jù)庫表里面的字段都是下劃線形式的,如financial_product_config_id。

結(jié)果發(fā)現(xiàn),返回的結(jié)果都是null,打印了SQL,確實(shí)查到了記錄,因此判定是結(jié)果集和返回類型的字段映射問題。

之前一直以為Mybatis會自動把數(shù)據(jù)庫下劃線字段轉(zhuǎn)換成POJO類(resultType對應(yīng)的類)的駝峰屬性字段,但是發(fā)現(xiàn)是自己記錯(cuò)了,這個(gè)Mybatis默認(rèn)不會自動轉(zhuǎn)換,所以返回結(jié)果為null,特此記錄。

解決辦法有下面幾種

1、select 字段時(shí),給數(shù)據(jù)庫下劃線字段加別名,改成對應(yīng)的類駝峰屬性字段,例如:

select financial_product_config_id as financialProductConfigId

2、不用resultType了,改用resultMap把下劃線字段和駝峰字段對應(yīng)上;

3、啟用Mybatis的mapUnderscoreToCamelCase為true,這樣就可以實(shí)現(xiàn)數(shù)據(jù)庫下劃線字段到POJO類駝峰形式的自動映射了。

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)文章

最新評論