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(jìn)行拼接
測試結(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類型進(jìn)行查詢
查看數(shù)據(jù)表字段
結(jié)論
mybatis的association在傳入字段時會自動進(jìn)行數(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-06Java 根據(jù)網(wǎng)址查詢DNS/IP地址的方法
這篇文章主要介紹了Java 根據(jù)網(wǎng)址查詢DNS/IP地址的方法,具體實現(xiàn)代碼,大家參考下本文2017-12-12帶有@Transactional和@Async的循環(huán)依賴問題的解決
這篇文章主要介紹了帶有@Transactional和@Async的循環(huán)依賴問題的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04