One approach would be to design your database similar to how you would define a class hierarchy, where you define base table(s) (classes) that provide the common attributes, and then you add additional tables that provide specific attributes to extend the table to the specific products.
Define a base product table
create table Products_base as
id
item
brand
model
description
size
color
price #more about this later
Define additional tables for products that differ substantially
create table pants as
base #foreign key to base product
waist
length
material
style
create table dress as
base #foreign key to base product table
waist
hemlength
bust
material
belt
Another approach would be to define the base product table, and then define an attributes table, and provide the attributes for each additional product,
create table Products_base as
id autoincrement
item
brand
model
description
size
color
price #more about this later
create table attributes as
id autoincrement
name
description
create table product_+attributes as
product_id #product.id
attribute_id #attributes.id
value
Using pants as an example, you would want to add attributes to pants (add to the attributes table)
"length", "length of item"
"inseam", "length of inseam"
"style", "style of article" #example, "jeans"
#etc
And then you would add values for the attributes
product.id("pants"), attribute.id("inseam"), "32in"
product.id("pants"), attribute.id("waist"), "34in"
product.id("pants"), attribute.id("style"), "jeans"
product.id("dress"), attribute.id("style"), "sundress"
#etc