1. 程式人生 > >Mapper.xml中對象的關聯

Mapper.xml中對象的關聯

-1 語句 屬性 mage 額外 man 才會 img pan

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

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

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

選用原則 :

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

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

技術分享

選用哪種方式?

選用發送一條額外sql

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

mapper.xml中關聯的寫法

技術分享

技術分享

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

樂觀鎖的問題

技術分享

技術分享

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

技術分享

Mapper.xml中對象的關聯