微服务实战——属性分组与各类对象

属性分组

/**
 * 获取分类属性分组
 * select * from pms_attr_group where catelog_id = ?
 * and (attr_group_id = ? or attr_group_name like ? or descript like ?)
 * @param params
 * @param catelogId
 * @return
 */
@Override
public PageUtils queryPage(Map<String, Object> params, Long catelogId) {

    // 1.构造通用wrapper
    QueryWrapper<AttrGroupEntity> wrapper = new QueryWrapper<AttrGroupEntity>();
    // 2.判断是否输入了 检索关键字:key
    String key = (String) params.get("key");
    if(!StringUtils.isEmpty(key)){
        wrapper.and((obj) -> obj.eq("attr_group_id", key)
                .or().like("attr_group_name", key)
                .or().like("descript", key));
    }

    // 3.判断是否选中分类id

    // 3.1.未选中(默认为0)
    if(catelogId == 0){
        IPage<AttrGroupEntity> page = this.page(
                new Query<AttrGroupEntity>().getPage(params),
                wrapper
        );
        return new PageUtils(page);
    }

    // 3.2.选中
    wrapper.eq("catelog_id", catelogId);

    // 返回分页对象
    IPage<AttrGroupEntity> page = this.page(
            new Query<AttrGroupEntity>().getPage(params),
            wrapper
    );
    return new PageUtils(page);
}
/**
 * 商品的子分类
 */
@JsonInclude(NON_EMPTY) // 为空时不携带该值
@TableField(exist = false)
private List<CategoryEntity> children;
/**
 * 级联选择器回显,查出该孩子的祖先路径
 */
@RequestMapping("/info/{attrGroupId}")
public R info(@PathVariable("attrGroupId") Long attrGroupId){
    AttrGroupEntity attrGroup = attrGroupService.getById(attrGroupId);

    Long catelogId = attrGroup.getCatelogId();
    // 根据catelogId查出分类路径
    Long[] path = categoryService.findCatelogPath(catelogId);
    attrGroup.setCatelogPath(path);
    return R.ok().put("attrGroup", attrGroup);
}
/**
 * 根据catelogId查出分类路径
 * @param catelogId
 * @return
 */
@Override
public Long[] findCatelogPath(Long catelogId) {
    List<Long> ids = new ArrayList<>();
    while(catelogId != 0){
        ids.add(catelogId);
        catelogId = query().eq("cat_id", catelogId).one().getParentCid();
    }
    Collections.reverse(ids);
    return ids.toArray(new Long[ids.size()]);
}

各类对象

1. PO(Persistent Object)

  • 持久对象,即在持久层与数据库中的表结构相对应的对象。通常是与数据库表一一对应的实体类,字段对应表的列。
  • 例如,数据库中有一个 User 表,PO 就是一个 User 类,代表一条记录。

2. VO(Value Object)

  • 值对象,通常用来表示数据的视图层,封装了一些业务数据,并且一般是只读的。
  • VO 通常用于向展示层传递数据,可以是与 PO 类似的结构,但可能只包含展示需要的字段,而不是数据库的全部字段。

3. BO(Business Object)

  • 业务对象,封装业务逻辑的对象。BO 代表在业务层操作的对象,它们通常包含业务逻辑或方法,与应用程序的业务流程密切相关。
  • BO 可能会调用多个 DAO 或与多个实体(DO)进行交互。

4. DO(Data Object)

  • 数据对象,也称为 Domain Object,通常与数据库中的表结构对应。DO 可以与 PO 类似,但在某些框架中会有所区分,DO 更注重领域层次的概念。
  • 例如,某个业务领域中的 Order 可以是一个 DO,用于表示领域内的订单数据和行为。

5. DAO(Data Access Object)

  • 数据访问对象,用于封装对数据库的访问操作。DAO 通过方法提供与数据库交互的接口,比如增删改查操作。
  • DAO 层将数据库操作封装成方法,使得业务逻辑不需要直接处理数据库的细节。

6. DTO(Data Transfer Object)

  • 数据传输对象,用于在不同层之间传输数据。DTO 一般是从业务层到表现层的数据封装,通常是 POJO。
  • DTO 通过序列化与反序列化机制进行传输,常用于分布式系统、远程调用或 API 接口的数据传输。

7. POJO(Plain Old Java Object)

  • 简单的Java对象,指的是没有任何特别要求的普通 Java 对象,没有继承或实现任何特殊的类或接口。
  • POJO 是最基本的对象结构,可以包含属性、Getter/Setter 方法、构造器等,但不应该有任何与特定框架相关的依赖
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值