A Better Way to Store Ecommerce Product Information

A Better Way to Store Ecommerce Product Information

July 3, 2016 2:05 pm
Amazon Web Services DynamoDB, MongoDB, Couchbase, and MarkLogic are all examples of NoSQL databases that may offer a better way to store product catalog information.

Amazon Web Services DynamoDB, MongoDB, Couchbase, and MarkLogic are all examples of NoSQL databases which will supply a greater solution to retailer product catalog info.

How an ecommerce website shops and accesses product info can have a big impression on website efficiency.

Online retail companies, small and enormous, might profit from a well-liked database know-how that would supply a greater strategy to retailer product info. To assist perceive this know-how, which is known as NoSQL, it will possibly assist to explain simply how complicated product info could be.

The Product Attribute Problem

Many — if not most — ecommerce platforms retailer product info in a relational database, the place info is stored in tables just like a spreadsheet. Imagine, for instance, a product itemizing for a small, pink t-shirt. The shirt may need a singular ID, a inventory protecting unit (SKU), a title, a measurement, and a shade.

ID SKU title measurement shade
B POI0987654321 Awesome Shirt s pink

Each of those 5 attributes would take up a column within the database desk. A row within the desk represents the entire set of product info.

For a website that sells solely t-shirts, this may work properly. You might think about further rows within the database desk representing further shirts, say the “Awesome Shirt,” in 4 sizes and two colours.

ID SKU title measurement shade
M POI0987654321 Awesome Shirt s purple
P POI0987654322 Awesome Shirt m purple
A POI0987654323 Awesome Shirt l pink
A POI0987654324 Awesome Shirt xl pink
H POI0987654325 Awesome Shirt s blue
S POI0987654326 Awesome Shirt m blue
S POI0987654327 Awesome Shirt l blue
H POI0987654328 Awesome Shirt xl blue

The database question to show this product info can be comparatively easy to write down and quick to load. Not a lot of an issue. But what if this t-shirt retailer additionally needs to promote pants?

Pants have a special set of attributes. Size just isn’t measured in small, medium, and enormous, however sometimes in waist and inseam.

To clear up this drawback, one might add columns to the desk.

ID SKU sort title measurement waist inseam shade
B POI0987654321 shirt Awesome Shirt s pink
P POI0987654322 shirt Awesome Shirt m purple
O POI0987654323 pants Neat Pants 30 30 black
A POI0987654324 pants Neat Pants 30 31 black

This will work, however it might not scale nicely. Imagine what would occur if the retailer added extra product varieties.

  • Belts. Need a size attribute and a cloth attribute.
  • Hats. Need a hat sort attribute (i.e., snap again or elastic).
  • Shoes. Need an attribute for lace size and the variety of islets.
  • Stickers. Need a peak, width, and adhesive sort attribute.
  • Music. Need an artist attribute and a method to retailer an inventory of tracks.
  • Movies. Need a director attribute and attributes for actors, the film’s score, the yr it was made, and extra.

All this, and within the instance, there’s not but an attribute for worth, sale worth, value, weight, delivery dimensions, or comparable.

Very shortly, the ecommerce product database desk can be lots of or hundreds of columns vast. What’s worse, a lot of the columns can be empty. The small, purple t-shirt would nonetheless want simply 5 or so columns, leaving hundreds clean. This single desk answer could be costly to host because it wastes reminiscence.

An ecommerce answer might get rid of the wasted area if it assigned every new product sort its personal desk.

There can be a product desk only for t-shirts.

T-shirt Product Table
ID SKU title measurement colour
B POI0987654321 Awesome Shirt s purple
P POI0987654322 Awesome Shirt m pink

A separate desk would retailer info for pants.

Pants Product Table
ID SKU title waist inseam shade
A POI0987654323 Neat Pants 30 30 black
A POI0987654324 Neat Pants 30 31 black

This answer would work, however it might be very onerous to handle.

For each new sort of product, there would must be a brand new, customized database desk. The ecommerce platform would wish to maintain monitor of all of those tables, together with understanding how they relate to one another.

Showing an inventory of merchandise from a single producer may take a number of database queries or “joins,” that are mixtures of columns from totally different tables.

A third answer to the product attribute drawback can be to implement an entity, attribute, worth system — EAV. Popular ecommerce platforms like Magento take this strategy.

EAV options regularly use a number of tables to retailer parts of the product info. Here’s the entity portion.

Product Entity Table
product ID SKU title
B POI0987654321 Awesome Shirt
P POI0987654322 Awesome Shirt
A POI0987654323 Neat Pants
A POI0987654324 Neat Pants

A totally different desk would retailer the worth for particular person attributes.

Product Attribute Table
product ID attribute worth
M measurement s
B colour pink
P measurement m
P shade pink
A waist 30
O inseam 30
O shade black
A waist 30
A inseam 31
A colour black

Here two tables are storing the product info, however there are EAV database options for product catalogs that embrace three, 4, 5, or extra separate database tables. This strategy could make accessing product info fairly sluggish. Nonetheless, EAV may be the perfect answer for relational databases, to handle a product catalog.

NoSQL for Ecommerce Product Information

NoSQL — non-relational databases — take a special strategy to storing info. There are not any tables of structured columns and rows. In a way, NoSQL trades consistency for availability, velocity, and adaptability.

Although non-relational databases or key-worth pair databases have been round for many years, NoSQL has lately grow to be well-liked with giant Internet companies, together with Google, Facebook, eBay, and Amazon. These corporations have to entry vital quantities of complicated info in a short time.

NoSQL structure differs amongst implementations. But basically, NoSQL will retailer all of an merchandise’s knowledge in a single container.

Thus, one product equals one container (typically referred to as an merchandise or a doc) within the database.

Sometimes, these things or paperwork might be in JSON format or comparable, which means that it’ll look very acquainted to net builders.

For an ecommerce product, there’ll sometimes be a singular merchandise ID, a set of widespread product attributes, and a few attributes which are distinctive to a specific product. The small pink shirt may seem like the next.

     unique_id: 'HY8765NBg6yYT77nBhNkln543NjNhYTR',
     sku: 'POI0987654321',
     sort: ‘t-shirt’,
     title: 'Amazing Shirt'
     attributes: 
         measurement: 's',
         colour: 'pink'
     
 

A specific pair of pants would have some issues in widespread with the shirt, however in NoSQL there can be the pliability to have totally different attributes.

     unique_id: '99iIiGtg6GHGjfj776098JjHGtgfffhhh',
     sku: 'POI0987654323',
     sort: 'pants',
     title: 'Neat Pants'
     attributes: 
          waist: '30',
          inseam: '30',
         colour: 'black'
     
 

With this strategy, a retailer might promote any type of product it needs with out having to switch a database desk or work out how you can maintain monitor of the different types of attributes. A belt would merely be one other container within the database.

     unique_id: 'jjfJlkjsdfALKJljJLKDJ877KJNBB',
     sku: 'BE1888477',
     sort: 'belt',
     title: 'Studded Belt'
     attributes: 
          measurement: '30',
          size: '30',
          colour: 'black',
          materials: 'leather-based'
     
 

In this manner, NoSQL is rather more versatile. It is just simpler to retailer and handle product knowledge. What’s extra, querying for a person product might be quicker. This is particularly true because the variety of merchandise within the database will increase.

NoSQL Considerations

An on-line retailer utilizing a SaaS ecommerce platform might not have the ability to reap the benefits of NoSQL. But retailers utilizing licensed ecommerce platforms or customized options might discover that NoSQL is a more sensible choice for product catalog info.

There are loads of purposes for which relational databases make extra sense, however NoSQL could be a higher answer for product info.


You may also like...