對象的關聯,特別是manytoone的關聯,有兩種方式:發送一條額外sql去查詢和內聯的方式
發送一條額外sql:當我在使用到這個關聯對象的時候,我發送一條額外的sql去把這個關聯的對象查詢出來,然后設置到對象里面,這樣容易造成n+1的問題
內聯方式:在這條sql直接把關聯的對象的表連接進來,把需要查詢的信息全部查出來,然后直接在resultMap中拼裝出關聯的對象,這樣就可以避免n+1的問題,但是會造成連接的性能損耗
選用原則 :
如果關聯的對象要在列表中顯示,那么直接使用內聯的方式,會造成表關聯的性能損耗
如果要在查看這個對象時才顯示,則選擇使用發送一條額外的sql進行查詢的方式,但是會造成n+1的問題
選用哪種方式?
選用發送一條額外sql
因為在列表中不用顯示借款人的信息,而是當我們要去查看這個借款人的信息時,當我們要去查看他的借款明細的時候,才會去點開看他的信息,這個屬性要查看某個對象時,才會顯示。
mapper.xml中關聯的寫法
使用發送額外的sql查詢,則下面這條sql語句不用變
樂觀鎖的問題
n+1問題,網上查了下資源