Mapper.xml中對象的關聯

來源:互聯網
上載者:User

標籤:2-2   需要   logs   image   XML   內聯   n+1   直接   寫法   

對象的關聯,特別是manytoone的關聯,有兩種方式:發送一條額外sql去查詢和內聯的方式

發送一條額外sql:當我在使用到這個關聯對象的時候,我發送一條額外的sql去把這個關聯的物件查詢出來,然後設定到對象裡面,這樣容易造成n+1的問題

內聯方式:在這條sql直接把關聯的對象的表串連進來,把需要查詢的資訊全部查出來,然後直接在resultMap中拼裝出關聯的對象,這樣就可以避免n+1的問題,但是會造成串連的效能損耗

選用原則 :

如果關聯的對象要在列表中顯示,那麼直接使用內聯的方式,會造成表關聯的效能損耗

如果要在查看這個對象時才顯示,則選擇使用發送一條額外的sql進行查詢的方式,但是會造成n+1的問題

選用哪種方式?

 選用發送一條額外sql

因為在列表中不用顯示借款人的資訊,而是當我們要去查看這個借款人的資訊時,當我們要去查看他的借款明細的時候,才會去點開看他的資訊,這個屬性要查看某個對象時,才會顯示。

 

mapper.xml中關聯的寫法

使用發送額外的sql查詢,則下面這條sql語句不用變

 

樂觀鎖的問題

 

 

 

n+1問題,網上查了下資源

 

Mapper.xml中對象的關聯

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.