mybatis 一對(duì)多collection結(jié)合分頁(yè)塞关、查詢條件問題解決

? ? 我們都知道在實(shí)際的開發(fā)中抬探,我們經(jīng)常遇到需要展示一對(duì)多的數(shù)據(jù)問題,如:一個(gè)人共有n個(gè)訂單帆赢,每個(gè)訂單有不定的商品小压,那么這種顯示的數(shù)據(jù)結(jié)構(gòu)就是我們的一對(duì)多數(shù)據(jù)結(jié)構(gòu):如下所示


訂單對(duì)應(yīng)商品數(shù)據(jù)結(jié)構(gòu)

? ? 應(yīng)為訂單的數(shù)據(jù)量大的問題,我們要采取分頁(yè)椰于,但是mybatis的一對(duì)多collection的分頁(yè)插件pagehelper的計(jì)算結(jié)果是錯(cuò)誤的怠益,錯(cuò)誤原因在于,一對(duì)多collection瘾婿,他計(jì)算的條數(shù)是按商品計(jì)算的(一對(duì)多的“多”蜻牢,而不是“一”),比如上圖中憋他,如果分頁(yè)參數(shù)是pageNum=1,pageSize=2,那么我們想要的結(jié)果應(yīng)該是上圖所示孩饼,但我們實(shí)際查詢出來的是,只有orderNo為1的那一部分竹挡。

? ? ? 如果采用collection的子查詢select來實(shí)現(xiàn)镀娶,那么分頁(yè)的問題是能解決了,但是其對(duì)查詢條件的支持很不友好揪罕,如果查詢條件的參數(shù)是訂單信息梯码,還可以支持,但是查詢條件一旦關(guān)聯(lián)到子查詢好啰,那么就實(shí)現(xiàn)gg了轩娶。

? ? 所以我們只能自己實(shí)現(xiàn)分頁(yè)插件,思路是:

一框往,按條件統(tǒng)計(jì)所有符合條件的訂單數(shù)量鳄抒,結(jié)果作為分頁(yè)結(jié)果的總條數(shù),sql語(yǔ)句為:select (distinct orderNo) from order_info left join order_goods_info..........where condition條件

二. 按條件查詢每個(gè)訂單的商品數(shù)量(分組統(tǒng)計(jì)),結(jié)果是一個(gè)integer的集合许溅,sql語(yǔ)句為select count(orderNo) from order_info left join order_goods_info...... where condition條件 group by order_info.orderNo

三.若分頁(yè)參數(shù)是pageNum(頁(yè)碼)瓤鼻,pageSize(頁(yè)容量),重新計(jì)算分頁(yè)查詢sql的limit參數(shù)skipNumber,pageSize

四.對(duì)步驟二返回的集合進(jìn)行截取求和贤重,計(jì)算pageNum頁(yè)之前所有的記錄條數(shù)skipNumber茬祷,結(jié)果作為,代碼為:int skipNumber = list.subList(0, (pageNum -1) * pageSize>list.size()?list.size():(pageNum -1) * pageSize).stream().mapToInt(Integer::intValue).sum();(想想為什么會(huì)有三元表達(dá)式)

五.計(jì)算pageSize:int pageSize= list.subList((pageNum -1) * pageSize, pageNum *pageSize>list.size()?list.size():pageNum*pageSize).stream().mapToInt(Integer::intValue).sum();

六.執(zhí)行sql查詢并蝗,編寫一對(duì)多collection 的mybatis映射

select 顯示元素.......from order_info left join order_goods_info .......where condition 條件 limit skipNumber,pageSize

部分代碼如下:


自定義分頁(yè)查詢

修改:其中condition.setTotal計(jì)算錯(cuò)誤祭犯,正確的應(yīng)該是carClassCount.size()

方案實(shí)現(xiàn)目標(biāo):一對(duì)多collection 查詢,可分頁(yè)滚停,查詢條件完美支持

缺點(diǎn):查詢次數(shù)增加一次(分組統(tǒng)計(jì))

注意:最后返回的分頁(yè)結(jié)果看起來?xiàng)l數(shù)不正常沃粗,那是你的參考對(duì)象錯(cuò)誤,真正的條數(shù)為一對(duì)多的“一”條數(shù)铐刘,而不是“多”的條數(shù)陪每,也就是訂單條數(shù)是真的影晓。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末镰吵,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子挂签,更是在濱河造成了極大的恐慌疤祭,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,464評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件饵婆,死亡現(xiàn)場(chǎng)離奇詭異勺馆,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)侨核,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門草穆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人搓译,你說我怎么就攤上這事悲柱。” “怎么了些己?”我有些...
    開封第一講書人閱讀 169,078評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵豌鸡,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我段标,道長(zhǎng)涯冠,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,979評(píng)論 1 299
  • 正文 為了忘掉前任逼庞,我火速辦了婚禮蛇更,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己派任,他們只是感情好共耍,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著吨瞎,像睡著了一般痹兜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上颤诀,一...
    開封第一講書人閱讀 52,584評(píng)論 1 312
  • 那天字旭,我揣著相機(jī)與錄音,去河邊找鬼崖叫。 笑死遗淳,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的心傀。 我是一名探鬼主播屈暗,決...
    沈念sama閱讀 41,085評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼脂男!你這毒婦竟也來了养叛?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,023評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤宰翅,失蹤者是張志新(化名)和其女友劉穎弃甥,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體汁讼,經(jīng)...
    沈念sama閱讀 46,555評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡淆攻,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嘿架。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓶珊。...
    茶點(diǎn)故事閱讀 40,769評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖耸彪,靈堂內(nèi)的尸體忽然破棺而出伞芹,到底是詐尸還是另有隱情,我是刑警寧澤搜囱,帶...
    沈念sama閱讀 36,439評(píng)論 5 351
  • 正文 年R本政府宣布丑瞧,位于F島的核電站,受9級(jí)特大地震影響蜀肘,放射性物質(zhì)發(fā)生泄漏绊汹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評(píng)論 3 335
  • 文/蒙蒙 一扮宠、第九天 我趴在偏房一處隱蔽的房頂上張望西乖。 院中可真熱鬧狐榔,春花似錦、人聲如沸获雕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)届案。三九已至庵楷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間楣颠,已是汗流浹背尽纽。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留童漩,地道東北人弄贿。 一個(gè)月前我還...
    沈念sama閱讀 49,191評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像矫膨,于是被迫代替她去往敵國(guó)和親差凹。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容

  • 本文包括:1侧馅、Hibernate 的查詢方式2危尿、HQL (Hibernate Query Language) 查詢...
    廖少少閱讀 2,665評(píng)論 0 15
  • 一眨眼就不見 觸不到的感覺 春風(fēng)拂面記憶中的笑臉 田間山野清晨雨露一路向前 雙眼不覺你的蒼老 直到山河改了顏 滄海...
    另外的另閱讀 239評(píng)論 0 0
  • “這個(gè)地方真是一坨屎脚线。” 這是你弥搞,經(jīng)過一天的旅途勞頓,到達(dá)目的地后渠旁,發(fā)出的感慨攀例。 為了來這里,你坐了紅眼航班顾腊,一晚...
    小極聊旅行閱讀 346評(píng)論 1 1
  • 什么是多線程粤铭?多線程與一般的程序不同,一般的程序都是單線順序執(zhí)行的杂靶,而多線程則是多個(gè)程序同時(shí)執(zhí)行梆惯。一般的程序就是一...
    玄薛燁閱讀 204評(píng)論 0 0
  • 夜,深了吗垮,聽著電臺(tái)垛吗,耳邊是主播舒緩的聲音,緩緩倒出的話語(yǔ)勾起內(nèi)心共鳴烁登。 張愛玲曾說:“有一種失落,不能說,只能靠感...
    殘殤_55a1閱讀 225評(píng)論 0 2