博客
关于我
四十一.属性分组新建关联-查询出分组未关联的属性
阅读量:246 次
发布时间:2019-02-28

本文共 2348 字,大约阅读时间需要 7 分钟。

属性分组关联功能开发说明

新建关联功能说明

在属性分组中,新增关联功能旨在帮助管理员高效管理属性与分组的关系。系统支持用户根据需要添加新的关联,具体功能如下:

  • 关联属性添加:用户可以选择需要关联的属性,系统会实时反馈操作结果
  • 关联属性管理:提供完整的属性列表供选择,支持批量操作
  • 关联规则优化:确保关联符合分类属性的规则,避免无效关联
  • 获取未关联属性

    在属性分组管理中,系统提供了获取未关联属性的功能,主要流程如下:

  • 筛选条件设置:支持通过属性名称、分类等条件筛选目标属性
  • 结果分页显示:返回结果以分页形式呈现,支持导出和继续查询
  • 关联属性检查:系统会自动筛选出未被当前分组关联的属性
  • 系统接口开发

    AttrGroupController 类

    新增接口 attrNoRelation,功能描述如下:

    @GetMapping("/{attrgroupId}/noattr/relation")public R attrNoRelation(@PathVariable Long attrgroupId, @RequestParam Map
    params) { PageUtils page = attrService.getNoRelationAttr(params, attrgroupId); return R.ok().put("page", page);}

    AttrService 类

    新增服务方法 getNoRelationAttr,具体功能描述如下:

    PageUtils getNoRelationAttr(Map
    params, Long attrgroupId);

    AttrServiceImpl 类

    实现 getNoRelationAttr 方法,具体实现逻辑如下:

    @Overridepublic PageUtils getNoRelationAttr(Map
    params, Long attrgroupId) { // 获取当前分组信息 AttrGroupEntity attrGroupEntity = attrGroupDao.selectById(attrgroupId); Long catelogId = attrGroupEntity.getCatelogId(); // 获取当前分类下的所有分组 List
    attrGroupEntities = attrGroupDao.selectList(new QueryWrapper
    () .eq("catelog_id", catelogId)); // 收集目标分组的attrGroup_id List
    collect = attrGroupEntities.stream() .map(item -> item.getAttrGroupId()) .collect(Collectors.toList()); // 获取目标分组关联的属性 List
    attrgroupRelationEntities = relationDao.selectList(new QueryWrapper
    () .in("attr_group_id", collect)); // 提取关联属性ID List
    attrIds = attrgroupRelationEntities.stream() .map(item -> item.getAttrId()) .collect(Collectors.toList()); // 构建查询条件 QueryWrapper
    wrapper = new QueryWrapper
    () .eq("catelog_id", catelogId) .eq("attr_type", ProductConstant.AttrEnum.ATTR_TYPE_BASE.getCode()); // 排除已关联的属性 if (attrIds != null && !attrIds.isEmpty()) { wrapper.notIn("attr_id", attrIds); } // 支持关键词搜索 String key = (String) params.get("key"); if (!StringUtils.isEmpty(key)) { wrapper.and((w) -> { w.eq("attr_id", key).or().like("attr_name", key); return w; }); } // 执行查询并返回结果 IPage
    page = this.page( new Query
    () .getPage(params), wrapper ); PageUtils pageUtils = new PageUtils(page); return pageUtils;}

    测试效果

    测试场景说明

  • 分类属性管理:影视分类下有多个属性,系统已关联部分属性
  • 关联属性展示:系统支持通过分组查看已关联的属性
  • 未关联属性查询:新增功能可帮助管理员识别未关联的属性
  • 批量关联处理:支持批量选择未关联属性进行关联操作
  • 通过以上功能,管理员可以高效管理属性分组关联关系,确保分类属性的准确性和完整性。

    转载地址:http://sxjp.baihongyu.com/

    你可能感兴趣的文章
    pandas :将时间戳转换为 datetime.date
    查看>>
    pandas :将行取消堆叠到新列中
    查看>>
    pandas DataFrame 中的自定义浮点格式
    查看>>
    Pandas DataFrame 的 describe()方法详解-ChatGPT4o作答
    查看>>
    Pandas DataFrame中删除列级的方法链接解决方案
    查看>>
    Pandas DataFrame中的列从浮点数输出到货币(负值)
    查看>>
    Pandas DataFrame中的列从浮点数输出到货币(负值)
    查看>>
    Pandas DataFrame多索引透视表-删除空头和轴行
    查看>>
    pandas DataFrame的一些操作
    查看>>
    Pandas Dataframe的日志文件
    查看>>
    Pandas df.iterrows() 并行化
    查看>>
    Pandas drop_duplicates 方法不适用于包含列表的数据框
    查看>>
    pandas groupby 和过滤器
    查看>>
    pandas GROUPBY+变换和多列
    查看>>
    pandas Groupby:创建两列的Groupby时,如何按正确的顺序对工作日进行排序?
    查看>>
    Pandas matplotlib 无法显示中文
    查看>>
    pandas PIVOT_TABLE保持索引
    查看>>
    Pandas Plots:周末的单独颜色,x 轴上漂亮的打印时间
    查看>>
    pandas to_latex() 转义数学模式
    查看>>
    Pandas | 频数统计很简单,但这5 种技巧你使用过吗?
    查看>>