Spring 四、 spring-mybaits 關聯查詢(二)

概念

所謂的一對一查詢,就是說我們在查詢一個表的數據的時候,需要關聯查詢其他表的數據

一對多(多對一)是指一方持有多方的引用。

實現方式

使用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>

最後我們查詢出來的對象裏就能包含我們關聯表的需要的字段了!

需要注意的是

  1. association 是一對一使用的屬性
  2. collection 是一對多使用的屬性
  3. 映射類中一對一是直接調用另外一個映射類
  4. 映射類中一對多是直接調用另外一個映射類集合
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章