原文寫于個(gè)人博客,歡迎關(guān)注www.xiaolewei.com
前言
公司上馬新項(xiàng)目,這個(gè)過程中重新研究了關(guān)于電商系統(tǒng)中的一些東西,參閱了shopNC的《高性能電子商務(wù)平臺(tái)構(gòu)建:架構(gòu)、設(shè)計(jì)與開發(fā)》(這本書說實(shí)話差強(qiáng)人意,一則設(shè)計(jì)思想講的過少,另外通篇的代碼也幾乎沒有太多參考價(jià)值),也看了網(wǎng)上不少博客,特記錄一下學(xué)習(xí)心得與感悟。
對(duì)于一個(gè)電商系統(tǒng),商品模塊顯然是其核心功能,商品模塊設(shè)計(jì)的好壞將直接決定后續(xù)的開發(fā)進(jìn)度和維護(hù)成本。
SKU
電商平臺(tái)上涉及到非常多的產(chǎn)品,這些產(chǎn)品五花八門,從書到電器,從衣服到家具,等等等等,書有出版社,衣服有顏色,手機(jī)有容量,屬性根據(jù)產(chǎn)品的不同也差別極大,對(duì)于我們而言又需要如何去抽象這些概念,如何去設(shè)計(jì)數(shù)據(jù)庫?
這里要提一個(gè)SKU
的概念
英文全稱為 stock keeping unit, 簡稱SKU,定義為保存庫存控制的最小可用單位
對(duì)于上述提到的每一件產(chǎn)品,他們?cè)趲齑嬷械淖钚”4鎲挝槐闶?code>sku,以iphone
為例,在倉庫中顯然不是以CPU
、屏幕
...這樣的方式存儲(chǔ)的,而是以單個(gè)完整的手機(jī)進(jìn)行存儲(chǔ)的。這里的每個(gè)被存儲(chǔ)的個(gè)體即為商品
。
屬性
每個(gè)商品都會(huì)有許多的屬性,對(duì)于衣服有尺碼、顏色,對(duì)于手機(jī)有屏幕尺寸、容量等。這些屬性又分為兩類,一類是會(huì)影響商品最終售價(jià)的關(guān)鍵屬性
,一類是說明性質(zhì)的屬性
,例如通常情況下顏色不影響手機(jī)價(jià)格,但是不同容量手機(jī)卻對(duì)應(yīng)不同價(jià)格,這里顏色就是普通屬性,而容量則為關(guān)鍵屬性。
產(chǎn)品 or 商品
我們定義真正用于平臺(tái)上交易的產(chǎn)品為商品。怎么理解?以iphone
為例,iphone7 plus
就是一個(gè)產(chǎn)品,這個(gè)產(chǎn)品有很多的屬性,如容量、顏色等。那么紅色的128G的iphone7 plus
是一個(gè)商品。也就是說平臺(tái)上賣出的是一個(gè)非常具體的個(gè)體,所以必然是可以被唯一確定的。而確定的方式就是前面提到的SKU
,即一個(gè)產(chǎn)品加上一組可以唯一確定其售價(jià)的關(guān)鍵屬性
即可稱為商品
數(shù)據(jù)庫設(shè)計(jì)
這里直接上ER圖
product_attrs
是屬性表,記錄一個(gè)商品可以擁有的屬性名,如容量
顏色
等,type
表示是否為關(guān)鍵屬性
。product_attr_values
是屬性值表,記錄某個(gè)屬性名對(duì)應(yīng)的屬性值。例如product_attrs
中有一條記錄:
id | name | type |
---|---|---|
1 | 容量 | 1 |
那么可以為其創(chuàng)建對(duì)應(yīng)的32G
、64G
的對(duì)應(yīng)值
id | name | product_attribute_id |
---|---|---|
1 | 32G | 1 |
2 | 64G | 1 |
-
products
表用于記錄產(chǎn)品的基本信息,可以任意擴(kuò)展。 -
items
與products
為多對(duì)一關(guān)系,一個(gè)item
通過關(guān)聯(lián)多個(gè)屬性,組成一個(gè)完整的商品
這里只是講一個(gè)思路。上述數(shù)據(jù)庫表還可以繼續(xù)完善擴(kuò)展。