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

product_attrs是屬性表,記錄一個商品可以擁有的屬性名,如容量顏色等,type表示是否為關(guān)鍵屬性。product_attr_values是屬性值表,記錄某個屬性名對應(yīng)的屬性值。例如product_attrs中有一條記錄:
| id | name | type |
|---|---|---|
| 1 | 容量 | 1 |
那么可以為其創(chuàng)建對應(yīng)的32G、64G的對應(yīng)值
| id | name | product_attribute_id |
|---|---|---|
| 1 | 32G | 1 |
| 2 | 64G | 1 |
-
products表用于記錄產(chǎn)品的基本信息,可以任意擴(kuò)展。 -
items與products為多對一關(guān)系,一個item通過關(guān)聯(lián)多個屬性,組成一個完整的商品
這里只是講一個思路。上述數(shù)據(jù)庫表還可以繼續(xù)完善擴(kuò)展。