java后台删除当前节点及其子节点(递归)

一、表设计

 二、entity

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.joyoung.cloud.security.common.entity.BaseEntity;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.experimental.Accessors;

import javax.persistence.Column;
import javax.persistence.Table;
import javax.persistence.Transient;
import java.io.Serializable;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

@ApiModel(value = "自助售卖产品销售区域架构表")
@Table(name = "sys_sellarea")
@Data
@Accessors(chain = true)
public class SysSellarea extends BaseEntity implements Serializable {
    private static final long serialVersionUID = 1L;


    /**
     * 销售区域编码
     */
    @Column(name = "sellarea_code")
    @ApiModelProperty(value = "销售区域编码")
    private String sellareaCode;

    /**
     * 销售区域名称
     */
    @Column(name = "sellarea_name")
    @ApiModelProperty(value = "销售区域名称")
    private String sellareaName;

    /**
     * 上级ID
     */
    @Column(name = "parent_id")
    @ApiModelProperty(value = "上级ID")
    private String parentId;

    /**
     * 地址
     */
    @Column(name = "path")
    @ApiModelProperty(value = "地址")
    private String path;

    /**
     * 等级
     */
    @Column(name = "path_level")
    @ApiModelProperty(value = "等级")
    private String pathLevel;

    /**
     * 排序
     */
    @Column(name = "seq")
    @ApiModelProperty(value = "排序")
    private BigDecimal seq;

    /**
     * 描述
     */
    @Column(name = "remark")
    @ApiModelProperty(value = "描述")
    private String remark;

    @Transient
    private boolean hasChecked;
    @Transient
    private boolean hasChildren;

    @Transient
    private List<SysSellarea> children = new LinkedList<SysSellarea>();


    @JsonIgnore
    public static List<SysSellarea> sortList(Map<String, SysSellarea> map) {
        List<SysSellarea> SysSellareaTree = new ArrayList<>();
        map.forEach((id, obj) -> {
            if (map.containsKey(obj.getParentId())) {
                map.get(obj.getParentId()).getChildren().add(obj);
            } else {
                SysSellareaTree.add(obj);
            }
        });
        return SysSellareaTree;
    }

}

三、controller

/**
     * 删除销售区域
     * @param id
     * @return
     */
    @Override
    @ApiOperation(value = "删除销售区域及下面所有销售区域")
    @DeleteMapping("/{id}")
    public Result del(@PathVariable String id) {
        service.del(id);
        return ResultGenerator.genSuccessResult();
    }

四、service

public interface SysSellareaService extends BaseService<SysSellarea> {

    void del(String id);
}

五、serviceimpl

@Service
@Transactional
public class SysSellareaServiceImpl extends BaseServiceImpl<SysSellareaDao, SysSellarea> implements SysSellareaService {
  
/**
     * 删除销售区域
     * @param id
     */
    @Override
    public void del(String id) {
        //删除该节点以及下面节点
        delete(id);
    }

    private void delete(String id){
        //删除该节点
        try {
            dao.deleteSellareaById(id);
            List<SysSellarea> sysSellareas = dao.selectListByParentId(id);
            //递归删除该节点下所有节点
            if (sysSellareas==null||sysSellareas.size()==0){
                return;
            }else {
                for (SysSellarea sysSellarea1 : sysSellareas){
                    delete(sysSellarea1.getId());
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
            throw new BaseSystemException(SELLAREA_DEL_FAIL.getCode(),SELLAREA_DEL_FAIL.getMsg());
        }
    }

}

六、dao

@Repository
public interface SysSellareaDao extends TKMapper<SysSellarea> {
/**
     * 根据parentId查询
     * @param parentId
     * @return
     */
    List<SysSellarea> selectListByParentId(String parentId);
}

七、mapper

 <select id="selectListByParentId" resultType="com.joyoung.cloud.security.common.entity.system.SysSellarea">
        SELECT
        <include refid="Sellarea_param"/>,
        EXISTS (SELECT id FROM sys_sellarea WHERE parent_id = ssa.id AND del_flag = 0) AS hasChildren
        FROM sys_sellarea ssa WHERE ssa.del_flag = 0 AND ssa.parent_id = #{parentId}
    </select>

 

posted @ 2023-07-04 15:36  江南大才子  阅读(261)  评论(0编辑  收藏  举报