淺談非小型電商系統(tǒng)——商品模塊設(shè)計(jì)

原文寫于個人博客,歡迎關(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ò)展。
  • itemsproducts為多對一關(guān)系,一個item通過關(guān)聯(lián)多個屬性,組成一個完整的商品

這里只是講一個思路。上述數(shù)據(jù)庫表還可以繼續(xù)完善擴(kuò)展。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容