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. 映射类中一对多是直接调用另外一个映射类集合
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值