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

原文寫于個(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)的32G64G的對(duì)應(yīng)值

id name product_attribute_id
1 32G 1
2 64G 1
  • products表用于記錄產(chǎn)品的基本信息,可以任意擴(kuò)展。
  • itemsproducts為多對(duì)一關(guān)系,一個(gè)item通過關(guān)聯(lián)多個(gè)屬性,組成一個(gè)完整的商品

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容