mysql - mybatis select語句問題
問題描述
消息提醒續(xù),這個消息可能是別人直接回復(fù)了你的文章,這時需要進(jìn)行數(shù)據(jù)庫操作關(guān)聯(lián)文章表獲取相應(yīng)文章的內(nèi)容【消息提醒:您的文章xxx有了新的回復(fù)】,也可能是別人回復(fù)了你的評論這時關(guān)聯(lián)的就是評論表來獲取評論的內(nèi)容【消息提醒:您的評論xxx有了新的回復(fù)】,消息點擊后即可出現(xiàn)顯示詳情這樣子。
數(shù)據(jù)庫表結(jié)構(gòu)如下
mbelongbid為消息所屬的文章的id,mbelongcid為消息所屬的評論的id。當(dāng)mbelongcid為空時說明消息是直接回復(fù)文章,此時關(guān)聯(lián)的是文章表;當(dāng)mbelongcid不為空時說明消息回復(fù)的對象是某一條評論,此時關(guān)聯(lián)的是評論表。
sql語句要怎么寫才能符合這種需求?現(xiàn)在的想法是:
select
r.*, <if test='mbelongcid == null'>`blog`.btitle</if><if test='mbelongcid != null'>`comment`.ccontent</if>
from (
select mid, mreferuid, mbelongbid, mbelongcidfrom messagewhere mid = #{_parameter}
)r, <if test='mbelongcid == null'>
`blog` where r.mbelongbid = `blog`.bid
</if> <if test='mbelongcid != null'>
`comment` where r.mbelongcid = `comment`.cid
</if>
直接這樣寫是有問題的,大致的想法就是根據(jù)mbelongcid是否為null去關(guān)聯(lián)不同的表獲取不同的字段,有沒有好的解決方案或者建議?
問題解答
回答1:mbelongcid不是你傳入的參數(shù)的一部分,所以mybatis并不知道它到底是不是null!,你要實現(xiàn)你想要的這種邏輯應(yīng)該從數(shù)據(jù)庫端去著手,比如創(chuàng)建一個視圖,這個視圖由兩個查詢union而成。
select mid, mreferuid, ’blog’ as type, mbelongbid as ridfrom message m, blog bwhere mbelongcid is null and mbelongbid is not null and mbelongbid = b.bidunionselect mid, mreferuid, ’comment’ as type, mbelongcid as ridfrom message m, comment cwhere mbelongcid is not null and mbelongcid = c.cid
當(dāng)你寫程序遇到這種需要很奇怪的語法的時候,請先回顧一下設(shè)計方案,通常緣由都是設(shè)計就有問題。
數(shù)據(jù)表誰設(shè)計的?扣工資 至少要加個下劃線啊m_belong_cid,學(xué)生黨,慢慢來吧。
回答2:我們項目用的是注解式SQL,遇到這類情況都是直接在Provider拼SQL解決。
回答3:MessageMapper.xml這部分的語句如下:
message類如下:
相關(guān)文章:
1. javascript - npm下載的模塊不完整是什么問題?2. 從事游戲服務(wù)端開發(fā)(Java),需要具備哪些技術(shù)???3. java - Spring事務(wù)回滾問題4. python 操作mysql如何經(jīng)量防止自己的程序在之后被惡意注入(說白了就是問一下python防注入的一些要點)5. 正兒八經(jīng)地請教天蓬老師6. 求一個mySQL安裝包7. 不能插入數(shù)據(jù)。8. mysql - 面試題:如何把login_log表轉(zhuǎn)換成last_login表?9. 剛放到服務(wù)器的項目出現(xiàn)這中錯誤,有高手指點嗎10. mysql 插入數(shù)值到特定的列一直失敗
