商品服务-API-规格参数

1. 新增规格参数

商品属性和属性分组在新增规格参数时应该相匹配。

  • 新增商品属性规格参数时

  • 需要同步将数据保存在关联表pms_attr_attrgroup_relation

Object 划分

1.PO(persistant object) 持久对象

PO 就是对应数据库中某个表中的一条记录,多个记录可以用PO 的集合。PO 中应该不包含任何对数据库的操作。

2.DO(Domain Object)领域对象

就是从现实世界中抽象出来的有形或无形的业务实体。

3.TO(Transfer Object) ,数据传输对象

不同的应用程序之间传输的对象

4.DTO(Data Transfer Object)数据传输对象

这个概念来源于J2EE 的设计模式,原来的目的是为了EJB 的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,泛指用于展示层与服务层之间的数据传输对象。

5.VO(value object) 值对象

通常用于业务层之间的数据传递,和PO 一样也是仅仅包含数据而已。但应是抽象出的业务对象, 可以和表对应, 也可以不, 这根据业务的需要。用new 关键字创建,由GC 回收的。

  • View object:视图对象;
  • 接受页面传递来的数据,封装对象
  • 将业务处理完成的对象,封装成页面要用的数据

6.BO(business object) 业务对象

从业务模型的角度看, 见UML 元件领域模型中的领域对象。封装业务逻辑的java 对象, 通过调用DAO 方法, 结合PO,VO 进行业务操作。business object: 业务对象主要作
用是把业务逻辑封装为一个对象。这个对象可以包括一个或多个其它的对象。比如一个简历,有教育经历、工作经历、社会关系等等。我们可以把教育经历对应一个PO ,工作经历对应一个PO ,社会关系对应一个PO 。建立一个对应简历的BO 对象处理简历,每个BO 包含这些PO 。这样处理业务逻辑时,我们就可以针对BO 去处理。\

7.POJO(plain ordinary java object) 简单无规则java 对象

传统意义的java 对象。就是说在一些Object/Relation Mapping 工具中,能够做到维护数据库表记录的persisent object 完全是一个符合Java Bean 规范的纯Java 对象,没有增加别的属性和方法。我的理解就是最基本的java Bean ,只有属性字段及setter 和getter方法!。
POJO 是DO/DTO/BO/VO 的统称。

8.DAO(data access object) 数据访问对象

是一个sun 的一个标准j2ee 设计模式, 这个模式中有个接口就是DAO ,它负持久层的操作。为业务层提供接口。此对象用于访问数据库。通常和PO 结合使用, DAO 中包含了各种数据库的操作方法。通过它的方法, 结合PO 对数据库进行相关的操作。夹在业务逻辑与数据库资源中间。配合VO, 提供数据库的CRUD 操作.

1.1 新增VO

前端提交的数据字段多于数据库表中的字段时,之前封装对象是在实体类中添加一个字段,同时告诉springMVC该字段不属于数据库表。

  • 这样写不规范,以后不同业务场景会封装不同的实体类,如果都在一个实体类中操作,会造成不方便阅读。
@TableField(exist =false)
private Long[] catelogPath;

新增一个VO对象

@Data
public class AttrVo {
    private Long attrId;
    /**
     * 属性名
     */
    private String attrName;
    /**
     * 是否需要检索[0-不需要,1-需要]
     */
    private Integer searchType;
    /**
     * 属性图标
     */
    private String icon;
    /**
     * 可选值列表[用逗号分隔]
     */
    private String valueSelect;
    /**
     * 属性类型[0-销售属性,1-基本属性,2-既是销售属性又是基本属性]
     */
    private Integer attrType;
    /**
     * 启用状态[0 - 禁用,1 - 启用]
     */
    private Long enable;
    /**
     * 所属分类
     */
    private Long catelogId;
    /**
     * 快速展示【是否展示在介绍上;0-否 1-是】,在sku中仍然可以调整
     */
    private Integer showDesc;
    //多搜集一个attrGroupId
    private Long attrGroupId;
}

1.1.1 保存attr

controller

@RequestMapping("/save")
//@RequiresPermissions("product:attr:save")
public R save(@RequestBody AttrVo attr){
    attrService.saveAttr(attr);
    return R.ok();
}

service

@Override
@Transactional //事务
public void saveAttr(AttrVo attr) {
    //1.先保存到数据表
    AttrEntity entity = new AttrEntity();
    //将封装后的前端数据映射给AttrEntity
    BeanUtils.copyProperties(attr,entity);
    this.save(entity);
    //2.保存到关联表
    AttrAttrgroupRelationEntity relationEntity = new AttrAttrgroupRelationEntity();
    Long attrGroupId = attr.getAttrGroupId();
    relationEntity.setAttrGroupId(attrGroupId);
    relationEntity.setAttrId(entity.getAttrId());
    attrAttrgroupRelationService.save(relationEntity);
}

关联表数据保存成功

posted @ 2022-03-11 14:25  初夏那片海  阅读(62)  评论(0)    收藏  举报