分布式电商项目三十八:分组关联属性删除功能

分组关联属性功能

在分类下的分组中,需要关联基本属性,用于商品页面的展示:
在这里插入图片描述
本章完成分组关联属性的功能。对应的API文档如下:
在这里插入图片描述
请求是/product/attrgroup/{attrgroupId}/attr/relation;首先来到响应控制层,添加响应处理:

    @Autowired
    AttrService attrService;

    /**
     * 处理响应 product/attrgroup/{attrgroupId}/attr/relation
     * 返回分组对应的属性
     */
   
    @GetMapping("/{attrgroupId}/attr/relation")
    public R attrRelation(@PathVariable("attrgroupId") Long attrgroupId){
        List<AttrEntity> entities =  attrService.getRelationAttr(attrgroupId);
        return R.ok().put("data",entities);
    }

之后创建和实现方法getRelationAttr:

  /**
     * 根据分组id查找关联的所有基本属性
     * @param  attrgroupId 分组id
     * @return List<AttrEntity>
     */
    @Override
    public List<AttrEntity> getRelationAttr(Long attrgroupId) {
        List<AttrAttrgroupRelationEntity> entities = relationDao.selectList(new QueryWrapper<AttrAttrgroupRelationEntity>().eq("attr_group_id", attrgroupId));
        //收集ID的集合
        List<Long> attrIds = entities.stream().map((attr) -> {
            return attr.getAttrId();
        }).collect(Collectors.toList());

        if(attrIds == null || attrIds.size() == 0){
            return null;
        }
        //根据属性ID查找所以的属性集合
        Collection<AttrEntity> attrEntities = this.listByIds(attrIds);
        return (List<AttrEntity>) attrEntities;
    }

重启服务来到前端进行测试关联属性能够正确显示:
在这里插入图片描述

删除关联属性

对应API接口文档:
在这里插入图片描述
发送一个post请求,携带的信息是attrId和attrGroupId。首先添加一个VO来保存这两条请求的信息:

package com.lastingwar.mall.product.vo;

import lombok.Data;

@Data
public class AttrGroupRelationVo {

    //"attrId":1,"attrGroupId":2
    private Long attrId;
    private Long attrGroupId;
}

之后来到控制层来编写对应的控制响应:

    /**
     * 完成响应product/attrgroup/attr/relation/delete,删除对应的关联
     * @param vos 请求的voAttrGroupRelationVo数组
     * @return R.ok
     */
    
    @PostMapping("/attr/relation/delete")
    public R deleteRelation(@RequestBody  AttrGroupRelationVo[] vos){
        attrService.deleteRelation(vos);
        return R.ok();
    }

之后创建方法实现方法deleteRelation,由于这里不止删除一条信息,所以可以自己写SQL语句,使用mybatis的语法进行遍历,具体实现如下:

    /**
     * 根据请求的数组,批量删除商品属性关联关系
     * @param vos AttrGroupRelationVo请求的数组
     */
    @Override
    public void deleteRelation(AttrGroupRelationVo[] vos) {
        //relationDao.delete(new QueryWrapper<>().eq("attr_id",1L).eq("attr_group_id",1L));
        //需要批量删除多条信息,所以使用自定义的sql语句。
        //先把数组转为列表,之后使用流式处理
        List<AttrAttrgroupRelationEntity> entities = Arrays.asList(vos).stream().map((item) -> {
            AttrAttrgroupRelationEntity relationEntity = new AttrAttrgroupRelationEntity();
            BeanUtils.copyProperties(item, relationEntity);
            return relationEntity;
        }).collect(Collectors.toList());
        relationDao.deleteBatchRelation(entities);
    }

之后需要AttrAttrgroupRelationDao 实现deleteBatchRelation(entities)方法来完成删除。快捷键创建出方法:

package com.lastingwar.mall.product.dao;

import com.lastingwar.mall.product.entity.AttrAttrgroupRelationEntity;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 属性&属性分组关联
 * 
 * @author yhm
 * @email 403627000@qq.com
 * @date 2020-05-29 16:37:08
 */
@Mapper
public interface AttrAttrgroupRelationDao extends BaseMapper<AttrAttrgroupRelationEntity> {

    void deleteBatchRelation(@Param("entities") List<AttrAttrgroupRelationEntity> entities);
}

之后点击生成对应的xml配置,配置内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.lastingwar.mall.product.dao.AttrAttrgroupRelationDao">

	<!-- 可根据自己的需求,是否要使用 -->
    <resultMap type="com.lastingwar.mall.product.entity.AttrAttrgroupRelationEntity" id="attrAttrgroupRelationMap">
        <result property="id" column="id"/>
        <result property="attrId" column="attr_id"/>
        <result property="attrGroupId" column="attr_group_id"/>
        <result property="attrSort" column="attr_sort"/>
    </resultMap>
    <delete id="deleteBatchRelation">

        DELETE FROM `pms_attr_attrgroup_relation` WHERE
        <foreach collection="entities" item="item" separator=" OR ">
            (attr_id=#{item.attrId} AND attr_group_id=#{item.attrGroupId})
        </foreach>
    </delete>


</mapper>

即可完成多条信息的删除。之后重启服务进行测试:点击关联中的删除,响应删除成功:
在这里插入图片描述

之后到数据库中更新之后看到关联表内容被删除:
在这里插入图片描述
至此关联属性的删除功能完成。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值