一對(duì)多分頁(yè)的SQL應(yīng)該怎么寫(xiě)

本篇文章為大家展示了一對(duì)多分頁(yè)的SQL應(yīng)該怎么寫(xiě),內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

創(chuàng)新互聯(lián)專(zhuān)注于企業(yè)營(yíng)銷(xiāo)型網(wǎng)站、網(wǎng)站重做改版、韓城網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5響應(yīng)式網(wǎng)站、成都商城網(wǎng)站開(kāi)發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性?xún)r(jià)比高,為韓城等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

前言

MySQL一對(duì)多的數(shù)據(jù)分頁(yè)是非常常見(jiàn)的需求,比如我們要查詢(xún)商品和商品的圖片信息。但是很多人會(huì)在這里遇到分頁(yè)的誤區(qū),得到不正確的結(jié)果。今天就來(lái)分析并解決這個(gè)問(wèn)題。

2. 問(wèn)題分析

我們先創(chuàng)建一個(gè)簡(jiǎn)單商品表和對(duì)應(yīng)的商品圖片關(guān)系表,它們之間是一對(duì)多的關(guān)系:

一對(duì)多分頁(yè)的SQL應(yīng)該怎么寫(xiě)

然后我分別寫(xiě)入了一些商品和這些商品對(duì)應(yīng)的圖片,通過(guò)下面的左連接查詢(xún)可以看出它們之間具有明顯的一對(duì)多關(guān)系:

SELECT P.PRODUCT_ID, P.PROD_NAME, PI.IMAGE_URL FROM PRODUCT_INFO P          LEFT JOIN PRODUCT_IMAGE PI                    ON P.PRODUCT_ID = PI.PRODUCT_ID

一對(duì)多分頁(yè)的SQL應(yīng)該怎么寫(xiě)

按照傳統(tǒng)的思維我們的分頁(yè)語(yǔ)句會(huì)這么寫(xiě):

<resultMap id="ProductDTO" type="cn.felord.mybatis.entity.ProductDTO">     <id property="productId" column="product_id"/>     <result property="prodName" column="prod_name"/>     <collection property="imageUrls"  ofType="string">         <result column="image_url"/>     </collection> </resultMap>  <select id="page" resultMap="ProductDTO">     SELECT P.PRODUCT_ID, P.PROD_NAME,PI.IMAGE_URL     FROM PRODUCT_INFO P              LEFT JOIN PRODUCT_IMAGE PI                        ON P.PRODUCT_ID = PI.PRODUCT_ID     LIMIT #{current},#{size} </select>

當(dāng)我按照預(yù)想傳入了(0,2)想拿到前兩個(gè)產(chǎn)品的數(shù)據(jù),結(jié)果并不是我期望的:

2020-06-21 23:35:54.515 DEBUG 10980 --- [main] c.f.m.mappers.ProductInfoMapper.page     : ==>  Preparing: SELECT P.PRODUCT_ID, P.PROD_NAME,PI.IMAGE_URL FROM PRODUCT_INFO P LEFT JOIN PRODUCT_IMAGE PI ON P.PRODUCT_ID = PI.PRODUCT_ID limit ?,?  2020-06-21 23:35:54.541 DEBUG 10980 --- [main] c.f.m.mappers.ProductInfoMapper.page     : ==> Parameters: 0(Long), 2(Long) 2020-06-21 23:35:54.565 DEBUG 10980 --- [main] c.f.m.mappers.ProductInfoMapper.page     : <==      Total: 2 page = [ProductDTO{productId=1, prodName='杯子', imageUrls=[http://asset.felord.cn/cup1.png, http://asset.felord.cn/cup2.png]}]

我期望的兩條數(shù)據(jù)是杯子和筆記本,但是結(jié)果卻只有一條。原來(lái)當(dāng)一對(duì)多映射時(shí)結(jié)果集會(huì)按照多的一側(cè)進(jìn)行輸出(期望4條數(shù)據(jù),實(shí)際上會(huì)有7條),而前兩條展示的只會(huì)是杯子的數(shù)據(jù)(如上圖),合并后就只有一條結(jié)果了,這樣分頁(yè)就對(duì)不上了。那么如何才能達(dá)到我們期望的分頁(yè)效果呢?

3. 正確的方式

正確的思路是應(yīng)該先對(duì)主表進(jìn)行分頁(yè),再關(guān)聯(lián)從表進(jìn)行查詢(xún)。

拋開(kāi)框架,我們的SQL應(yīng)該先對(duì)產(chǎn)品表進(jìn)行分頁(yè)查詢(xún)?nèi)缓笤僮箨P(guān)聯(lián)圖片表進(jìn)行查詢(xún):

SELECT P.PRODUCT_ID, P.PROD_NAME, PI.IMAGE_URL FROM (SELECT PRODUCT_ID, PROD_NAME       FROM PRODUCT_INFO       LIMIT #{current},#{size}) P          LEFT JOIN PRODUCT_IMAGE PI                    ON P.PRODUCT_ID = PI.PRODUCT_ID

這種寫(xiě)法的好處就是通用性強(qiáng)一些。但是MyBatis提供了一個(gè)相對(duì)優(yōu)雅的路子,思路依然是開(kāi)頭所說(shuō)的思路。只不過(guò)我們需要改造上面的Mybatis  XML配置:

<resultMap id="ProductDTO" type="cn.felord.mybatis.entity.ProductDTO">     <id property="productId" column="product_id"/>     <result property="prodName" column="prod_name"/>      <!-- 利用 collection 標(biāo)簽提供的 select 特性 和 column   -->     <collection property="imageUrls" ofType="string" select="selectImagesByProductId" column="product_id"/> </resultMap> <!-- 先查詢(xún)主表的分頁(yè)數(shù)據(jù)    --> <select id="page" resultMap="ProductDTO">     SELECT PRODUCT_ID, PROD_NAME     FROM PRODUCT_INFO     LIMIT #{current},#{size} </select> <!--根據(jù)productId 查詢(xún)對(duì)應(yīng)的圖片--> <select id="selectImagesByProductId" resultType="string">     SELECT IMAGE_URL     FROM PRODUCT_IMAGE     WHERE PRODUCT_ID = #{productId} </select>

大部分情況下分頁(yè)是很容易的,但是一對(duì)多還是有一些小小的陷阱的。一旦我們了解了其中的機(jī)制,也并不難解決。

上述內(nèi)容就是一對(duì)多分頁(yè)的SQL應(yīng)該怎么寫(xiě),你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

新聞標(biāo)題:一對(duì)多分頁(yè)的SQL應(yīng)該怎么寫(xiě)
網(wǎng)頁(yè)路徑:http://muchs.cn/article22/pieejc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站網(wǎng)站維護(hù)、企業(yè)網(wǎng)站制作、手機(jī)網(wǎng)站建設(shè)、電子商務(wù)網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)