概念
所謂的一對一查詢,就是說我們在查詢一個表的數據的時候,需要關聯查詢其他表的數據
一對多(多對一)是指一方持有多方的引用。
實現方式
使用resultMap實現
使用resultType實現
SQL語句需要使用連接查詢
SQL語句需要使用嵌套查詢
栗子
表映射類
@Data
public class Cart {
private Integer cartId;
/**
* 購買數量
*/
private Integer num;
/**
* 用戶ID
*/
private Integer uid;
/**
* 商品ID
*/
private Integer shopId;
private Date createDate;
/**
* 0 表示刪除 1表示正常
*/
private Byte status;
private Shop shop;
}
注意我們需要在映射類中給一個關聯查詢的表字段,之後mybaits回給我們的對象中就會有主表和副表的全部字段了
對應的mapper文件
/**
* 通過用戶id去查詢所有的商品信息
* @param uid 用戶id
* @return 集合Cart
*/
List<Cart> findCartByUid(@Param("uid") int uid);
mapper.xml文件
<!--主表的數據庫映射文件-->
<resultMap id="cartShopResult" type="Cart">
<id column="cart_id" property="cartId"/>
<result property="num" column="num"/>
<result property="uid" column="uid"/>
<result property="shopId" column="shop_id"/>
<!-- 一對一 -->
<association property="shop"
<!--副表的數據庫映射對象-->
resultMap="com.wener.shop.mapper.ShopMapper.BaseResultMap"/>
</resultMap>
<!--SQL語句-->
<select id="findCartByUid" resultMap="cartShopResult">
SELECT c.cart_id, c.num, c.uid, c.shop_id, c.create_date, c.status,
s.shop_id, s.title, s.name, s.price, s.img, s.num
FROM cart c LEFT JOIN shop s ON c.shop_id = s.shop_id
WHERE c.status = 0 AND s.status = 0 AND c.uid = #{uid}
</select>
<!--副表的映射文件-->
<resultMap id="BaseResultMap" type="Shop">
<id property="shopId" column="shop_id" />
<result property="oldPrice" column="old_price"/>
<result property="status" column="status"/>
<result property="img" column="img"/>
<result property="name" column="name"/>
<result property="createDate" column="create_date"/>
<result property="num" column="num"/>
</resultMap>
最後我們查詢出來的對象裏就能包含我們關聯表的需要的字段了!
需要注意的是
- association 是一對一使用的屬性
- collection 是一對多使用的屬性
- 映射類中一對一是直接調用另外一個映射類
- 映射類中一對多是直接調用另外一個映射類集合