zoukankan      html  css  js  c++  java
  • 电商开发必备,淘宝商品和类目体系是如何设计的

    在阿里做过几年电商业务,越发认识到,做电商的,怎么都绕不过商品,

    商品作为电商体系中最重要的业务模型,不管是在电商供应链、电商营销,还是电商推荐,以及电商广告中,都有很重要的意义,

    最近几年特别火的千人千面,商品知识图谱,都离不开商品数据的支持。

     

    这篇文章基于淘宝的电商业务,从概念分析,到领域模型,再到上层应用,对商品和类目体系进行一个简单拆解。

    一、如何定义商品

    在展开分析之前,先来思考一个问题,追根溯源,什么是商品?

    1.1 商品是货品的数字化

    理解一个概念,不能离开上下文。

    这篇文章描述的是电商领域中的商品,电商对应的是线下零售,在电商业务中,商品就是通过把不同的属性集合在一起,描述客观世界的实物。

    为了更加真实和准确的反映实物,我们通过创建不同的模型,组合不同的属性去描述商品。也就是说,商品可以理解为线下实物商品的数字化。

    商品连接交易,电商时代的特点是一切皆可交易,所以商品的概念也越来越宽泛。

     

    不过还是推荐大家去读一些零售相关的书籍,了解下线下零售的发展,有助于加深对电商的理解。

    1.2 如何理解商品模型

    实物商品在线下是如何流通的?

    那么到了线上,商品如何流转?

     既然是流转,那就会有一个链路,围绕商品领域,可以把整个电商上下游分为供应链路和销售链路。

    大家都学习过计算机网络原理,我们在学习网络协议的时候,信息的传输是需要网络协议来管理,网络协议定义了编码和解码的规范。

    类似的,商品信息在线上的流转,需要一个模型去承载,也就是商品模型。

    二、商品与产品

    通用的电商商品模型包括商品、SPU以及SKU,以及在这个基础上发展出来CSPU的概念,形成了下面的结构。

     

    在业务中,通过SPU和CSPU对商家发布商品进行强管控,同时对商家对SPU和CSPU属性的填充,又扩充了基础属性和基础属性值库,在运营审核的过程中,这些基础属性添加到标准属性和对应的类目属性下。

    2.1 商品

    商品特指与商家有关的商品,商品通过SKU和库存,来对应到线下的实物商品。每个商品会对应一个商家,每个商品下面有多个颜色,款式,可以有多个SKU。

    例如,Iphone 12是一款产品,但是当平台上很多商家在出售这个产品的时候,我们就把Iphone 12 称为一个商品。

    2.2 SKU

    SKU的英文是 stock keeping unit(库存单位),SKU即库存进出计量的单位,可以是以件、盒、托盘等为单位。在服装、鞋类商品中使用最多最普遍。

      

    2.3 SPU

    在谈到SPU之前,先来思考一下,有了类目和SKU,为什么要定义一个SPU?

    SPU概念的出现,是为了满足在叶子类目下对商品进行进一步抽象的需求。

    还是用手机举例子,一般来说,手机就是叶子类目,那么我能不能添加几个苹果手机/华为手机的类目呢?

    当然可以,但是这样类目树就会变得非常庞大,所以,SPU是在「对商品约束进一步细化的需求」中各方平衡的结果。

    SPU(Standard Product Unit) 标准产品单元,是对某一类标准产品的共同特征属性的描述,是商品信息共有属性的一种抽取,在淘系商品中,SPU是由后台类目+一组关键类目属性唯一确定。

    SPU 是一个介于叶子类目和商品之间的概念, 是对类目的细化,是商品标准化运营的基础。

    SPU有哪些应用呢?

    举几个简单的例子,淘宝购物车的找相似功能,就是通过SPU去关联商品。

    还记得多年之前轰轰烈烈的比价网站吗,比价网站的核心业务就是围绕SPU。

    2.4 CSPU

    CSPU是淘宝特色的一个商品模型,这里的C是Child的意思,也就是子标准化产品单元,即SPU的细分,更细粒度的标识产品。

    “类目+关键属性+销售属性”唯一确定一个的细粒度产品CSPU。

     比如手机类型下,品牌和型号这两个属性可以确定一个SPU,但还不能标示一个CSPU,需要额外的销售属性来确定;

    以苹果手机为例,品牌是IPhone,型号是12,颜色为深灰色,存储卡256G,两个关键属性是品牌和型号,两个销售属性为颜色和存储卡。

    三、类目属性体系

    类目属性体系和商品领域相辅相成,打个不恰当的比方,类目树是坐标轴,类目属性是坐标,商品就是其中的点。

     

    3.1 类目定义

    类目是商品所属的分类,类目决定了商品的归属。

    类目是有层次的,分为一级类目、二级类目等,之间有继承关系,通常是通过类目树来展现。

    比如厨房电器这个一级类目下,有电磁炉,冰箱等二级类目,电磁炉下面还会有细分的三级类目,类目树的最下面一层类目是叶子类目,一般来说,只有叶子类目才可以下挂商品。

    3.2 前后台类目

    通常来说,电商业务里有两大类型的类目体系,一种类型是后台类目,主要用于商家发布商品;另外一种类型是前台类目,主要用于前台商品导购。

    (1)后台类目,关注标准化管理

    后台类目是商品的实际归属类目,卖家在发布商品时,将商品发布到指定的后台类目下。淘系定义的类目最多四层,类目层级太深会影响商家商品发布的体验。

    (2)前台类目,关注灵活的导购

    前台类目用于在前台进行导航,展现,搜索定位用,前台类目中保存的,实际上是对后台类目/属性的筛选条件,即映射条件。

     

      

    用户通过前台类目搜索到该类目所映射的后台类目下挂靠的商品,但是商品只归属于一个后台类目。

    前台类目主要用来导购,导购路径过长会导致转化率下降,一般来说,前台类目不会超过3层。

    3.3 类目属性及分类

    类目属性是类目下的商品所具有的共同特征定义,关联叶子类目和属性,比如手机类目具有品牌、型号、颜色、网络等属性。

    和类目属性对应的是类目属性值,表示类目下的商品所具有的某一个特征的值。

    属性是用来描述商品的,为了更好的对商品进行描述,对类目属性进行一层抽象,也就是类目属性分类。

    一般的,类目属性可以进一步分为关键属性,绑定属性,销售属性,商品属性。

    四、属性库建设

    属性用于描述商品具有的特性,比如颜色、尺码,只靠属性不能描述商品,需要说明属性值才可以。

    读到这里你肯定也意识到了,属性库其实类似元数据的概念,也就是「描述商品数据的数据」。

    4.1 属性数据从哪里来

    属性库既然是元数据,就要支持大部分的商品描述,目前主流电商平台的属性库数量都是在百亿级别。

    现在思考一个问题,那么这么多属性,都是靠运营手工录入的吗?

    对于平台型电商来说,属性库的数据来源,一部分来自各个行业的标准化委员会,比如服装有全国服装标准化委员会,洗衣机有家电标准化委员会,然后运营去手工录入。

    另外大部分数据,来自商家和平台的共建,也就是通过商家来输入。

    这里又有一个问题,如果商家在发布商品时创建一个根本不存在的属性,比如上架一部手机,内存选择100TB,平台如何解决这种问题呢?

    典型的解决方案,就是淘宝的商品审核机制。

    以淘系为例,属性库分为标准属性库和基础属性库,其实就是对应两套数据表。

    基础属性库和属性值来自商家发布商品时录入,类目运营通过人工审核、算法审核等方式,会把部分属性添加到标准属性库。

    4.2 标准属性和基础属性

    标准属性库维护的是经过审核的,类目上直接可用的属性,而基础属性库,来自商家在发布商品和spu过程中直接录入的数据。

      

    经过运营审核、机器审核、数据清洗等流程,基础属性数据会流入到标准属性,作为整个平台属性库的扩充,在其他商家录入商品时,可以直接依赖,实现属性的复用。

    4.3 属性如何管理

    属性库不只有K-V结构这么简单,还需要一些别的规则来约束。

    (1)输入类型

    属性有一个概念叫输入类型,因为不同的属性有的可以枚举,有的只能文本输入。

    比如商品的产地,是固定的行政区域,但是如果是重量,就没办法通过枚举表示完全。

    一般来说,属性可以分为枚举,枚举可输入,可输入三种,另外某些复杂类目下还有属性模板的定义,用于某些无法提前枚举的子属性填充。

    (2)多级属性

    特别的,部分属性有子属性的概念,比如阿迪达斯的三叶草系列,就是隶属于阿迪达斯这个品牌属性值下边的。

    如果没有子属性的概念,单纯通过笛卡尔积来表示,在发布商品时就会出现太多的属性值并列,导致无法筛选,并且出现很多不存在的属性组合,而多级属性,就可以解决这个问题。

    五、供应链商品

    上面的商品模型,都是偏向销售链路,在供应链路,商品模型又会有一切不同,简单列举几点。

    5.1 前后端商品

    刚才说到,标准的电商类目体系会分为前台类目和后台类目,其实在商品模型中,也会分成前端商品和后端商品。

    前端商品关注销售链路,包括交易,订单等,后端商品关注供应链路,包括仓储,采购等。

    为什么要分前端商品和后端商品呢?

    前端商品可以理解为分销商品,后端商品可以理解为供销商品。

    举个例子,你在网上购买一个空调,实际上呢,这个空调分为室内主机和外机,内机和外机在仓储上和可能是分开的。

    为了解决这种情况,就可以通过前后端商品模型,将前端的空调商品,与后端的空调内机和外机关联起来,最终计算库存时,是使用内机商品和外机商品的库存。

    5.2 组合商品

    还记得啤酒与尿不湿的故事吗?

     

    商品在销售过程中,常见的一个形式是组合商品,比如购买手机的电话卡套餐,双十一商家的套餐商品,都可以通过组合商品的方式来实现。

    六、小结

     这篇文章简单分析了商品、类目、属性库三层的业务模型,对于平台型电商来说,商品管理核心解决两个问题,一个是商品的标准化,另外一个是商品导购,而这些都离不开业务模型的支持。

    模型的第一性

    埃隆马斯克有个特别推崇的第一性原理,第一性原理要求我们回归本质,找寻最基本的要素,建立更简洁完整的架构体系。

    商品模型的变化,都是为了更好的描述现实世界的实物商品,满足业务要求。

    从这个角度看,电商业务中,商品模型就具有第一性,熟悉了底层商品模型,在面对上层的各种业务变化,就可以游刃有余。

    题图来自 Unsplash,基于 CC0 协议

    作者:邴越
    扫码关注公众号:架构进化论,获得第一手的技术资讯和原创文章
    如果文章对您有帮助,可以点击文章右下角【推荐】一下,您的鼓励是作者坚持原创和持续写作的最大动力!
  • 相关阅读:
    tfs中如何创建团队项目及如何操作团队项目
    Qt出现常量有换行符的错误的解决方法
    .net程序在无.net环境下运行
    无法定位程序输入点__gxx_personality_v0的一个解决方法
    SQL Server2012中的SequenceNumber
    GDB十分钟教程
    使用vscode对c进行调试
    sqlserver 操作xml
    使用HttpOnly提升Cookie安全性
    SQL localdb 连接字符串
  • 原文地址:https://www.cnblogs.com/binyue/p/14329936.html
Copyright © 2011-2022 走看看