当前位置:首页 > 科技  > 软件

一文搞懂大厂商品中心设计!

来源: 责编: 时间:2024-06-27 07:57:25 69观看
导读1 雪花算法使用IdWorker idWorker=new IdWorker(1,1);for(int i=0;i<10000;i++){ long id = idWorker.nextId(); System.out.println(id);}配置分布式ID生成器将IdWorker.java拷贝到util包在工程的resources下

1 雪花算法使用

IdWorker idWorker=new IdWorker(1,1);for(int i=0;i<10000;i++){    long id = idWorker.nextId();    System.out.println(id);}

配置分布式ID生成器

  • 将IdWorker.java拷贝到util包
  • 在工程的resources下新增applicationContext-service.xml
<!‐‐雪花ID生成器‐‐><bean id="idWorker" class="com.qingcheng.util.IdWorker">    <constructor‐arg index="0" value="1"></constructor‐arg>    <constructor‐arg index="1" value="1"></constructor‐arg></bean>

2 新增和修改商品

2.1 表结构

t_spu 表

字段名称
tBh28资讯网——每日最新资讯28at.com

字段含义
tBh28资讯网——每日最新资讯28at.com

字段类型
tBh28资讯网——每日最新资讯28at.com

字段长度
tBh28资讯网——每日最新资讯28at.com

备注
tBh28资讯网——每日最新资讯28at.com

id
tBh28资讯网——每日最新资讯28at.com

主键
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

sn
tBh28资讯网——每日最新资讯28at.com

货号
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

name
tBh28资讯网——每日最新资讯28at.com

SPU名
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

caption
tBh28资讯网——每日最新资讯28at.com

副标题
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

brand_id
tBh28资讯网——每日最新资讯28at.com

品牌ID
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

category1_id
tBh28资讯网——每日最新资讯28at.com

一级分类
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

category2_id
tBh28资讯网——每日最新资讯28at.com

二级分类
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

category3_id
tBh28资讯网——每日最新资讯28at.com

三级分类
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

template_id
tBh28资讯网——每日最新资讯28at.com

模板ID
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

freight_id
tBh28资讯网——每日最新资讯28at.com

运费模板id
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

image
tBh28资讯网——每日最新资讯28at.com

图片
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

images
tBh28资讯网——每日最新资讯28at.com

图片列表
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

sale_service
tBh28资讯网——每日最新资讯28at.com

售后服务
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

introduction
tBh28资讯网——每日最新资讯28at.com

介绍
tBh28资讯网——每日最新资讯28at.com

TEXT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

spec_items
tBh28资讯网——每日最新资讯28at.com

规格列表
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

para_items
tBh28资讯网——每日最新资讯28at.com

参数列表
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

sale_num
tBh28资讯网——每日最新资讯28at.com

销量
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

comment_num
tBh28资讯网——每日最新资讯28at.com

评论数
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

is_marketable
tBh28资讯网——每日最新资讯28at.com

是否上架
tBh28资讯网——每日最新资讯28at.com

CHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

is_enable_spec
tBh28资讯网——每日最新资讯28at.com

是否启用规格
tBh28资讯网——每日最新资讯28at.com

CHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

is_delete
tBh28资讯网——每日最新资讯28at.com

是否删除
tBh28资讯网——每日最新资讯28at.com

CHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

status
tBh28资讯网——每日最新资讯28at.com

审核状态
tBh28资讯网——每日最新资讯28at.com

CHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

t_sku 表

字段名称
tBh28资讯网——每日最新资讯28at.com

字段含义
tBh28资讯网——每日最新资讯28at.com

字段类型
tBh28资讯网——每日最新资讯28at.com

字段长度
tBh28资讯网——每日最新资讯28at.com

备注
tBh28资讯网——每日最新资讯28at.com

id
tBh28资讯网——每日最新资讯28at.com

商品id
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

sn
tBh28资讯网——每日最新资讯28at.com

商品条码
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

name
tBh28资讯网——每日最新资讯28at.com

SKU名称
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

price
tBh28资讯网——每日最新资讯28at.com

价格(分)
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

num
tBh28资讯网——每日最新资讯28at.com

库存数量
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

alert_num
tBh28资讯网——每日最新资讯28at.com

库存预警数量
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

image
tBh28资讯网——每日最新资讯28at.com

商品图片
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

images
tBh28资讯网——每日最新资讯28at.com

商品图片列表
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

weight
tBh28资讯网——每日最新资讯28at.com

重量(克)
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

create_time
tBh28资讯网——每日最新资讯28at.com

创建时间
tBh28资讯网——每日最新资讯28at.com

DATETIME
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

update_time
tBh28资讯网——每日最新资讯28at.com

更新时间
tBh28资讯网——每日最新资讯28at.com

DATETIME
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

spu_id
tBh28资讯网——每日最新资讯28at.com

SPUID
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

category_id
tBh28资讯网——每日最新资讯28at.com

类目ID
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

category_name
tBh28资讯网——每日最新资讯28at.com

类目名称
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

brand_name
tBh28资讯网——每日最新资讯28at.com

品牌名称
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

spec
tBh28资讯网——每日最新资讯28at.com

规格
tBh28资讯网——每日最新资讯28at.com

VARCHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

sale_num
tBh28资讯网——每日最新资讯28at.com

销量
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

comment_num
tBh28资讯网——每日最新资讯28at.com

评论数
tBh28资讯网——每日最新资讯28at.com

INT
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

status
tBh28资讯网——每日最新资讯28at.com

商品状态 1-正常,2-下架,3-删除
tBh28资讯网——每日最新资讯28at.com

CHAR
tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com


tBh28资讯网——每日最新资讯28at.com

2.2 需求与实现

2.2.1 需求分析

详见静态原型。tBh28资讯网——每日最新资讯28at.com

2.2.2 实现思路

前端传递给后端的数据格式:tBh28资讯网——每日最新资讯28at.com

{    "spu": {        "name": "这个是商品名称",        "caption": "这个是副标题",        "brandId": 12,        "category1Id": 558,        "category2Id": 559,        "category3Id": 560,        "freightId": 10,        "image": "http://www.qingcheng.com/image/1.jpg",        "images": "http://www.qingcheng.com/image/1.jpg,http://www.qingcheng.com/image/2.jpg",        "introduction": "这个是商品详情,html代码",        "paraItems": {            "出厂年份": "2019",            "赠品": "充电器"        },        "saleService": "七天包退,闪电退货",        "sn": "020102331",        "specItems": {            "颜色": [                "红",                "绿"            ],            "机身内存": [                "64G",                "8G"            ]        },        "templateId": 42    },    "skuList": [        {            "sn": "10192010292",            "num": 100,            "alertNum": 20,            "price": 900000,            "spec": {                "颜色": "红",                "机身内存": "64G"            },            "image": "http://www.qingcheng.com/image/1.jpg",            "images": "http://www.qingcheng.com/image/1.jpg,http://www.qingcheng.com/image/2.jpg",            "status": "1",            "weight": 130        },        {            "sn": "10192010293",            "num": 100,            "alertNum": 20,            "price": 600000,            "spec": {                "颜色": "绿",                "机身内存": "8G"            },            "image": "http://www.qingcheng.com/image/1.jpg",            "images": "http://www.qingcheng.com/image/1.jpg,http://www.qingcheng.com/image/2.jpg",            "status": "1",            "weight": 130        }    ]}

2.3 代码实现

2.3.1 SPU与SKU列表的保存

/*** 商品组合实体类 */public class Goods implements Serializable {    private Spu spu;    private List<Sku> skuList;}

SpuServiceImpl新增方法:tBh28资讯网——每日最新资讯28at.com

@Autowiredprivate SkuMapper skuMapper;@Autowired  private IdWorker idWorker;@Autowiredprivate CategoryMapper categoryMapper;/*** 保存商品* @param goods 商品组合实体类*/@Transactionalpublic void saveGoods(Goods goods) {    // 保存一个spu的信息    Spu spu = goods.getSpu();    spu.setId(idWorker.nextId()+"");    spuMapper.insert(spu);        //保存sku列表的信息    Date date=new Date();    //分类对象    Category category = categoryMapper.selectByPrimaryKey(spu.getCategory3Id());    List<Sku> skuList = goods.getSkuList();    for (Sku sku:skuList){        sku.setId(idWorker.nextId()+"");        sku.setSpuId(spu.getId());        //sku名称 =spu名称+规格值列表        String name=spu.getName();        //sku.getSpec() {"颜色":"红","机身内存":"64G"}        Map<String,String> specMap = JSON.parseObject(sku.getSpec(), Map.class);        for(String value:specMap.values()){            name+=" "+value;        }        sku.setName(name);//名称        sku.setCreateTime(date);//创建日期        sku.setUpdateTime(date);//修改日期        sku.setCategoryId(spu.getCategory3Id());//分类id        sku.setCategoryName(category.getName());//分类名称        sku.setCommentNum(0);//评论数        sku.setSaleNum(0);//销售数量        skuMapper.insert(sku);    }}

该方法要对两个表操作,需添加事务:tBh28资讯网——每日最新资讯28at.com

@Service(interfaceClass=SpuService.class)

在类上加@Transactional,并在@Service注解中指定接口为SpuService.class。tBh28资讯网——每日最新资讯28at.com

SpuController修改add方法:tBh28资讯网——每日最新资讯28at.com

@PostMapping("/save")public Result save(@RequestBody Goods goods){    spuService.saveGoods(goods);    return new Result();}

3 建立分类与品牌的关联

3.1 需求

Q:为什么要建立分类与品牌的关联?tBh28资讯网——每日最新资讯28at.com

A:因为我们在前台搜索时,需要通过分类找到品牌列表。tBh28资讯网——每日最新资讯28at.com

Q:分类与品牌是什么关系?tBh28资讯网——每日最新资讯28at.com

A:多对多。tBh28资讯网——每日最新资讯28at.com

Q:在什么地方添加关系?tBh28资讯网——每日最新资讯28at.com

A:我们不在后台单独实现分类与品牌的关联,而是在添加商品时自动添加关联。tBh28资讯网——每日最新资讯28at.com

3.2 实现思路

  • 设计中间表tb_category_brand表
  • 创建实体类、数据访问接口
  • 在添加商品的saveGoods方法中添加代码逻辑 ,将SPU的品牌编号和分类编号一起插入到(中间表)

3.3 代码

创建实体类

@Table(name="tb_category_brand")@Datapublic class CategoryBrand implements Serializable {    @Id    private Integer categoryId;    @Id     private Integer brandId;}

联合主键,templateId和brandId都有@Id注解。tBh28资讯网——每日最新资讯28at.com

新建数据访问接口

public interface CategoryBrandMapper extends Mapper<CategoryBrand> {}

修改saveGoods方法

CategoryBrand categoryBrand =new CategoryBrand();categoryBrand.setBrandId(spu.getBrandId());categoryBrand.setCategoryId(spu.getCategory3Id());int count=categoryBrandMapper.selectCount(categoryBrand);if(count==0) {    categoryBrandMapper.insert(categoryBrand);}

4 根据ID查询商品

根据id 查询SPU和SKU列表 ,显示效果:tBh28资讯网——每日最新资讯28at.com

{    "spu": {        "brandId": 0,        "caption": "111",        "category1Id": 558,        "category2Id": 559,        "category3Id": 560,        "commentNum": null,        "freightId": null,        "id": 149187842867993,        "image": null,        "images": null,        "introduction": null,        "isDelete": null,        "isEnableSpec": "0",        "isMarketable": "1",        "name": "黑马智能手机",        "paraItems": null,        "saleNum": null,        "saleService": null,        "sn": null,        "specItems": null,        "status": null,        "templateId": 42    },    "skuList": [        {            "alertNum": null,            "brandName": "金立(Gionee)",            "categoryId": 560,            "categoryName": "手机",            "commentNum": null,            "createTime": "2018‐11‐06 10:17:08",            "id": 1369324,            "image": null,            "images": "blob:http://localhost:8080/ec04d1a5‐d865‐4e7f‐a313‐2e9a76cfb3f8",            "name": "黑马智能手机",            "num": 100,            "price": 900000,            "saleNum": null,            "sn": "",            "spec": null,            "spuId": 149187842867993,            "status": "1",            "updateTime": "2018‐11‐06 10:17:08",            "weight": null        },        {            "alertNum": null,            "brandName": "金立(Gionee)",            "categoryId": 560,            "categoryName": "手机",            "commentNum": null,            "createTime": "2018‐11‐06 10:17:08",            "id": 1369325,            "image": null,            "images": "blob:http://localhost:8080/ec04d1a5‐d865‐4e7f‐a313‐2e9a76cfb3f8",            "name": "黑马智能手机",            "num": 100,            "price": 900000,            "saleNum": null,            "sn": "",            "spec": null,            "spuId": 149187842867993,            "status": "1",            "updateTime": "2018‐11‐06 10:17:08",            "weight": null        }    ]}

4.1 代码

SpuService方法

/*** 根据ID查询商品* @param id * @return*/public Goods findGoodsById(String id){    //查询spu    Spu spu = spuMapper.selectByPrimaryKey(id);        //查询SKU 列表    Example example=new Example(Sku.class);    Example.Criteria criteria = example.createCriteria();    criteria.andEqualTo("spuId",id);    List<Sku> skuList = skuMapper.selectByExample(example);        //封装,返回    Goods goods=new Goods();    goods.setSpu(spu);    goods.setSkuList(skuList);    return goods;}

SpuController

@GetMapping("/findGoodsById")public Goods findGoodsById(Long id){    return spuService.findGoodsById(id);}

5 保存修改

实现思路

  • 修改与新增共用同一个方法
  • 通过spu的id判断当前操作是新增还是修改
  • 如果是新增需要设置spu的id,对spu执行的是insert操作
  • 如果修改则需要删除原来的sku列表,对spu执行的是updateByPrimaryKeySelective操作
  • sku列表的插入部分的代码要判断sku是否有id,如果有id则不重新生成id

代码实现

修改SpuServiceImpl的saveGoods:tBh28资讯网——每日最新资讯28at.com

/*** 保存商品* @param goods*/@Transactionalpublic void saveGoods(Goods goods) {    //保存一个spu的信息    Spu spu = goods.getSpu();    if(spu.getId()==null){//新增商品        spu.setId(idWorker.nextId()+"");        spuMapper.insert(spu);    }else{ //修改        //删除原来的sku列表        Example example=new Example(Sku.class);        Example.Criteria criteria = example.createCriteria();        criteria.andEqualTo("spuId",spu.getId());        skuMapper.deleteByExample(example);        //执行spu的修改        spuMapper.updateByPrimaryKeySelective(spu);    }    //保存sku列表的信息    List<Sku> skuList = goods.getSkuList();    for (Sku sku:skuList){        if(sku.getId()==null){//新增            sku.setId(idWorker.nextId()+"");            sku.setCreateTime(date);//创建日期        }        //添加sku    }//建立分类和品牌的关联}

6 未启用规格的sku处理

6.1 需求分析

有些商品没区分规格,即一个spu对应一个sku ,这时sku列表只传递一条记录,且无规格(spec)属性,要对其判断,避免因空值产生异常。tBh28资讯网——每日最新资讯28at.com

6.2 实现思路

在saveGoods方法的sku列表循环中添加代码,判断tBh28资讯网——每日最新资讯28at.com

// 构建SKU名称,采用SPU+规格值组装if(sku.getSpec()==null || "".equals(sku.getSpec())){    sku.setSpec("{}");}

7 商品审核与上下架

7.1 商品审核

7.1.1 需求分析与实现思路

商品审核:新录入的商品是未审核状态,也是未上架状态。tBh28资讯网——每日最新资讯28at.com

实现思路

  • 修改审核状态,如果审核状态为1,则上架状态也修改为1
  • 记录商品审核记录
  • 记录商品日志

7.1.2 代码实现

/*** 商品审核* @param id* @param status* @param message*/@Transactionalpublic void audit(String id, String status, String message) {    //1.修改状态 审核状态和上架状态    Spu spu = new Spu();    spu.setId(id);    spu.setStatus(status);    if("1".equals(status)){//审核通过        spu.setIsMarketable("1");//自动上架    }    spuMapper.updateByPrimaryKeySelective(spu);        //2.记录商品审核记录        //3.记录商品日志}
@GetMapping("/audit")public Result audit(Long id){    spuService.audit(id);    return new Result();}

7.2 下架商品

7.2.1 需求与实现思路

下架商品,修改上下架状态为下架。下架商品不修改审核状态。 下架商品需要记录商品日志。tBh28资讯网——每日最新资讯28at.com

7.2.2 代码实现

/*** 下架商品* @param id*/public void pull(String id) {    Spu spu = spuMapper.selectByPrimaryKey(id);    spu.setIsMarketable("0");//下架状态    spuMapper.updateByPrimaryKeySelective(spu);}
@GetMapping("/pull")public Result pull(String id){    spuService.pull(id);    return new Result();}

7.3 上架商品

7.3.1 需求分析

将商品修改为上架状态,需要验证该商品是否审核通过,未审核通过的商品不能上架。 上架商品需要记录商品日志。tBh28资讯网——每日最新资讯28at.com

7.3.2 代码实现

通过审核的商品才能上架:tBh28资讯网——每日最新资讯28at.com

/*** 商品上架* @param id*/public void put(String id) {    //1.修改状态    Spu spu = spuMapper.selectByPrimaryKey(id);    if(!"1".equals(spu.getStatus())){        throw new RuntimeException("此商品未通过审核");    }    spu.setIsMarketable("1");    spuMapper.updateByPrimaryKeySelective(spu);        //2.记录商品日志}
@GetMapping("/put")public Result put(String id){    spuService.put(id);    return new Result();}

7.4 批量上下架

7.4.1 需求分析

前端传递一组商品ID,后端进行批量上下架处理,处理后给前端返回处理的条数tBh28资讯网——每日最新资讯28at.com

7.4.2 代码实现

/*** 批量上架商品* @param ids*/public int putMany(Long[] ids) {    Spu spu=new Spu();    spu.setIsMarketable("1");//上架        //批量修改    Example example=new Example(Spu.class);    Example.Criteria criteria = example.createCriteria();    criteria.andIn("id", Arrays.asList(ids));//id    criteria.andEqualTo("isMarketable","0");//下架    criteria.andEqualTo("status","1");//审核通过的    criteria.andEqualTo("isDelete","0");//非删除的    return spuMapper.updateByExampleSelective(spu, example);}
@GetMapping("/putMany")public Result putMany(Long[] ids){    int count = spuService.putMany(ids);    return new Result(0,"上架"+count+"个商品");}

8 删除与还原商品

8.1 需求分析

删除商品并非物理删除(真正的执行删除数据),而是通过将表中某字段标记为删除状态。tBh28资讯网——每日最新资讯28at.com

还原商品实际就是将删除状态再修改回来。tBh28资讯网——每日最新资讯28at.com

如果商品需要物理删除,必须是先逻辑删除才能进行物理删除,删除前需要检查状态。tBh28资讯网——每日最新资讯28at.com

8.2 实现思路

  • 逻辑删除商品,修改spu表is_delete字段为1
  • 商品回收站显示spu表is_delete字段为1的记录
  • 回收商品,修改spu表is_delete字段为0

本文链接:http://www.28at.com/showinfo-26-96760-0.html一文搞懂大厂商品中心设计!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 日志打印的这10个坑,你至少踩过一个...

下一篇: 2024 最新最全 VS Code 插件推荐!

标签:
  • 热门焦点
  • 小米官宣:2023年上半年出货量中国第一!

    小米官宣:2023年上半年出货量中国第一!

    今日早间,小米电视官方微博带来消息,称2023年小米电视上半年出货量达到了中国第一,同时还表示小米电视的巨屏风暴即将开始。“公布一个好消息2023年#小米电视上半年出货量中国
  • 2023 年的 Node.js 生态系统

    2023 年的 Node.js 生态系统

    随着技术的不断演进和创新,Node.js 在 2023 年达到了一个新的高度。Node.js 拥有一个庞大的生态系统,可以帮助开发人员更快地实现复杂的应用。本文就来看看 Node.js 最新的生
  • .NET 程序的 GDI 句柄泄露的再反思

    .NET 程序的 GDI 句柄泄露的再反思

    一、背景1. 讲故事上个月我写过一篇 如何洞察 C# 程序的 GDI 句柄泄露 文章,当时用的是 GDIView + WinDbg 把问题搞定,前者用来定位泄露资源,后者用来定位泄露代码,后面有朋友反
  • 微软邀请 Microsoft 365 商业用户,测试视频编辑器 Clipchamp

    微软邀请 Microsoft 365 商业用户,测试视频编辑器 Clipchamp

    8 月 1 日消息,微软近日宣布即将面向 Microsoft 365 商业用户,开放 Clipchamp 应用,邀请用户通过该应用来编辑视频。微软于 2021 年收购 Clipchamp,随后开始逐步整合到 Microsof
  • 腾讯盖楼,字节拆墙

    腾讯盖楼,字节拆墙

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之&ldquo;想重温暴刷深渊、30+技能搭配暴搓到爽的游戏体验吗?一起上晶核,即刻暴打!&rdquo;曾凭借直播腾讯旗下代理格斗游戏《DNF》一
  • 腾讯VS网易,最卷游戏暑期档,谁能笑到最后?

    腾讯VS网易,最卷游戏暑期档,谁能笑到最后?

    作者:无锈钵来源:财经无忌7月16日晚,上海1862时尚艺术中心。伴随着幻象的精准命中,硕大的荧幕之上,比分被定格在了14:12,被寄予厚望的EDG战队以绝对的优势战胜了BLG战队,拿下了总决
  • iQOO Neo8 Pro评测:旗舰双芯加持 最强性能游戏旗舰

    iQOO Neo8 Pro评测:旗舰双芯加持 最强性能游戏旗舰

    【Techweb评测】去年10月,iQOO推出了一款Neo7手机,该机搭载了联发科天玑9000+,配备独显芯片Pro+,带来了同价位段最佳的游戏体验,一经上市便受到了诸多用
  • iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • OPPO K11搭载高性能石墨散热系统:旗舰同款 性能凉爽释放

    OPPO K11搭载高性能石墨散热系统:旗舰同款 性能凉爽释放

    日前OPPO官方宣布,将于7月25日14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖点就是将配备索尼
Top