Mybatis的association使用子查詢結(jié)果錯(cuò)誤的問題解決
代碼
<?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)行拼接
測(cè)試結(jié)果如圖
問題1:association傳入的column列自動(dòng)映射為null
這個(gè)目前不清楚原因
解決辦法
可以通過手動(dòng)配置映射解決
<resultMap type="LgsProfitForecast" id="LgsProfitForecastResult"> <result property="type" column="type"/> <association property="predictionCompletionDateStr" select="selectPredictionCompletionDateStr" column="type" javaType="string"/> </resultMap>
測(cè)試:
可見賦值正常,但是子查詢結(jié)果還是有問題
問題2:association子查詢結(jié)果全部相同
查看控制臺(tái)日志發(fā)現(xiàn)
實(shí)體類是int類型,但是傳入?yún)?shù)自動(dòng)變成boolean類型
數(shù)據(jù)庫測(cè)試
存的是數(shù)字,但可以用boolean類型進(jìn)行查詢
查看數(shù)據(jù)表字段
結(jié)論
mybatis的association在傳入字段時(shí)會(huì)自動(dòng)進(jìn)行數(shù)據(jù)庫的類型映射,而tinyint標(biāo)準(zhǔn)的類型映射為boolean類型。所以1,2,3參數(shù)映射全部為true,導(dǎo)致結(jié)果一致,且tinyint列在查詢時(shí)可以直接傳入boolean類型查詢,會(huì)自動(dòng)映射為0和1
解決
1.修改為int或者varchar類型
2.tinyint的長(zhǎng)度給大于1的數(shù)
3.數(shù)據(jù)庫jdbc連接添加參數(shù)tinyInt1isBit=false
測(cè)試
到此這篇關(guān)于Mybatis的association使用子查詢結(jié)果錯(cuò)誤的問題解決的文章就介紹到這了,更多相關(guān)Mybatis的association 子查詢 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mybatis中collection和association的使用區(qū)別詳解
- mybatis利用association或collection傳遞多參數(shù)子查詢
- Mybatis之a(chǎn)ssociation和collection用法
- 在Mybatis中association標(biāo)簽多層嵌套的問題
- mybatis中一對(duì)一關(guān)系association標(biāo)簽的使用
- MyBatis中association的基本使用方法
- mybatis的association傳遞參數(shù)問題示例
- Mybatis中一對(duì)多(collection)和一對(duì)一(association)的組合查詢使用
- MyBatis的collection和association的使用解讀
- mybatis中association標(biāo)簽的使用解讀
- MyBatis使用嵌套查詢collection和association的實(shí)現(xiàn)
相關(guān)文章
SpringBoot2.0解決Long型數(shù)據(jù)轉(zhuǎn)換成json格式時(shí)丟失精度問題
這篇文章主要介紹了SpringBoot2.0解決Long型數(shù)據(jù)轉(zhuǎn)換成json格式時(shí)丟失精度問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06Java 根據(jù)網(wǎng)址查詢DNS/IP地址的方法
這篇文章主要介紹了Java 根據(jù)網(wǎng)址查詢DNS/IP地址的方法,具體實(shí)現(xiàn)代碼,大家參考下本文2017-12-12帶有@Transactional和@Async的循環(huán)依賴問題的解決
這篇文章主要介紹了帶有@Transactional和@Async的循環(huán)依賴問題的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04Java實(shí)現(xiàn)圖片驗(yàn)證碼具體代碼
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)圖片驗(yàn)證碼具體代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10Java中的Callable實(shí)現(xiàn)多線程詳解
這篇文章主要介紹了Java中的Callable實(shí)現(xiàn)多線程詳解,接口Callable中有一個(gè)call方法,其返回值類型為V,這是一個(gè)泛型,值得關(guān)注的是這個(gè)call方法有返回值,這意味著線程執(zhí)行完畢后可以將處理結(jié)果返回,需要的朋友可以參考下2023-08-08