Mybatis的association使用子查詢結(jié)果錯誤的問題解決
代碼
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.li.application.mapper.LgsProfitForecastMapper">
<resultMap type="LgsProfitForecast" id="LgsProfitForecastResult">
<association property="predictionCompletionDateStr" select="selectPredictionCompletionDateStr"
column="type" javaType="string"/>
</resultMap>
<select id="selectProfitForecastList" resultMap="LgsProfitForecastResult">
SELECT
*
FROM
lgs_profit_forecast
</select>
<select id="selectPredictionCompletionDateStr" resultType="string">
select
GROUP_CONCAT(prediction_completion_date)
from
( select prediction_completion_date from lgs_profit_forecast where type = #{type} limit 4) a
</select>
</mapper>
需要子查詢?nèi)掌谶M行拼接
測試結(jié)果如圖

問題1:association傳入的column列自動映射為null
這個目前不清楚原因
解決辦法
可以通過手動配置映射解決
<resultMap type="LgsProfitForecast" id="LgsProfitForecastResult">
<result property="type" column="type"/>
<association property="predictionCompletionDateStr" select="selectPredictionCompletionDateStr"
column="type" javaType="string"/>
</resultMap>
測試:

可見賦值正常,但是子查詢結(jié)果還是有問題
問題2:association子查詢結(jié)果全部相同
查看控制臺日志發(fā)現(xiàn)


實體類是int類型,但是傳入?yún)?shù)自動變成boolean類型
數(shù)據(jù)庫測試

存的是數(shù)字,但可以用boolean類型進行查詢
查看數(shù)據(jù)表字段

結(jié)論
mybatis的association在傳入字段時會自動進行數(shù)據(jù)庫的類型映射,而tinyint標(biāo)準(zhǔn)的類型映射為boolean類型。所以1,2,3參數(shù)映射全部為true,導(dǎo)致結(jié)果一致,且tinyint列在查詢時可以直接傳入boolean類型查詢,會自動映射為0和1
解決
1.修改為int或者varchar類型
2.tinyint的長度給大于1的數(shù)
3.數(shù)據(jù)庫jdbc連接添加參數(shù)tinyInt1isBit=false
測試


到此這篇關(guān)于Mybatis的association使用子查詢結(jié)果錯誤的問題解決的文章就介紹到這了,更多相關(guān)Mybatis的association 子查詢 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mybatis中collection和association的使用區(qū)別詳解
- mybatis利用association或collection傳遞多參數(shù)子查詢
- Mybatis之a(chǎn)ssociation和collection用法
- 在Mybatis中association標(biāo)簽多層嵌套的問題
- mybatis中一對一關(guān)系association標(biāo)簽的使用
- MyBatis中association的基本使用方法
- mybatis的association傳遞參數(shù)問題示例
- Mybatis中一對多(collection)和一對一(association)的組合查詢使用
- MyBatis的collection和association的使用解讀
- mybatis中association標(biāo)簽的使用解讀
- MyBatis使用嵌套查詢collection和association的實現(xiàn)
相關(guān)文章
SpringBoot2.0解決Long型數(shù)據(jù)轉(zhuǎn)換成json格式時丟失精度問題
這篇文章主要介紹了SpringBoot2.0解決Long型數(shù)據(jù)轉(zhuǎn)換成json格式時丟失精度問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06
Java 根據(jù)網(wǎng)址查詢DNS/IP地址的方法
這篇文章主要介紹了Java 根據(jù)網(wǎng)址查詢DNS/IP地址的方法,具體實現(xiàn)代碼,大家參考下本文2017-12-12
帶有@Transactional和@Async的循環(huán)依賴問題的解決
這篇文章主要介紹了帶有@Transactional和@Async的循環(huán)依賴問題的解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

