Mapper.xml中對象的關聯


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

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

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

選用原則 :

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

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

選用哪種方式?

 選用發送一條額外sql

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

 

mapper.xml中關聯的寫法

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

 

樂觀鎖的問題

 

 

 

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM