动态分类的数据库架构

4

添加更新1,请在问题结束时检查。谢谢。

朋友们,

我正在设计一个产品列表,包括与类别和筛选器相关的内容。我目前有一个包含静态类别的数据库架构。我必须使它们动态化。我找不到使其动态化的正确架构,因此我在表格中硬编码了架构。我的详细工作如下:


MySQL 相关

主要产品表是所有产品的索引,每个产品类别都有单独的字段。例如,考虑一辆自行车和一台电视。这两个产品共享产品表中的公共字段:

  1. 产品编号
  2. 名称
  3. 价格
  4. 照片
  5. 分类

而分类则有一些额外的字段。因此,自行车属于汽车类别,其字段为:

  1. 里程
  2. 发动机类型
  3. 座位数
  4. 燃料

对于电视产品,它属于自己的类别 TV,其中字段为:

  1. 尺寸
  2. 视频类型
  3. 响应时间
  4. 输入选项

目前,我的数据库结构如下:

DESC `Products`;
+------------+--------------+------+-----+---------+----------------+
|      FIELD |         TYPE | NULL | KEY | DEFAULT |          EXTRA |
+------------+--------------+------+-----+---------+----------------+
| Product ID |      int(11) |   NO | PRI |  (null) | auto_increment |
|       Name | varchar(255) |  YES |     |  (null) |                |
|      Price |      int(11) |  YES |     |  (null) |                |
|      Photo | varchar(255) |  YES |     |  (null) |                |
|   Category |      int(11) |  YES |     |  (null) |                |
+------------+--------------+------+-----+---------+----------------+

分类字段如下:

DESC `television`;
+---------------+--------------+------+-----+---------+-------+
|         FIELD |         TYPE | NULL | KEY | DEFAULT | EXTRA |
+---------------+--------------+------+-----+---------+-------+
|    Product ID |      int(11) |  YES |     |  (null) |       |
|    Dimensions |  varchar(25) |  YES |     |  (null) |       |
|    Video Type | varchar(255) |  YES |     |  (null) |       |
| Response Time |  varchar(25) |  YES |     |  (null) |       |
| Input Options |         text |  YES |     |  (null) |       |
+---------------+--------------+------+-----+---------+-------+

DESC `automobiles`;
+-------------+--------------+------+-----+---------+-------+
|       FIELD |         TYPE | NULL | KEY | DEFAULT | EXTRA |
+-------------+--------------+------+-----+---------+-------+
|  Product ID |      int(11) |  YES |     |  (null) |       |
|     Mileage |      int(11) |  YES |     |  (null) |       |
| Engine Type | varchar(255) |  YES |     |  (null) |       |
|      Seater |      int(11) |  YES |     |  (null) |       |
|        Fuel | varchar(255) |  YES |     |  (null) |       |
+-------------+--------------+------+-----+---------+-------+

当我往数据库中插入数据时,我使用这种方式:

INSERT INTO `television`
    (`Product ID`, `Dimensions`, `Video Type`, `Response Time`, `Input Options`)
VALUES
    (1, 100, 'hd', 2, 'hd');
INSERT INTO `automobiles`
    (`Product ID`, `Mileage`, `Engine Type`, `Seater`, `Fuel`)
VALUES
    (1, 100, 'hd', 2, 'hd');

HTML / PHP

对于静态的分类集合,似乎使用类似以下简单表单的方式是可以的。

电视

<form action="new.php">
    <ul>
        <li>
            <label>Name</label>
            <input type="text" />
        </li>
        <li>
            <label>Price</label>
            <input type="text" />
        </li>
        <li>
            <label>Photo</label>
            <input type="text" />
        </li>
        <li>
            <label>Category</label>
            <input type="text" />
        </li>
        <li>
            <label>Dimensions</label>
            <input type="text" />
        </li>
        <li>
            <label>Video Type</label>
            <input type="text" />
        </li>
        <li>
            <label>Response Time</label>
            <input type="text" />
        </li>
        <li>
            <label>Input Options</label>
            <input type="text" />
        </li>
        <li>
            <input type="submit" />
        </li>
    </ul>
</form>

汽车

<form action="new.php">
    <ul>
        <li>
            <label>Name</label>
            <input type="text" />
        </li>
        <li>
            <label>Price</label>
            <input type="text" />
        </li>
        <li>
            <label>Photo</label>
            <input type="text" />
        </li>
        <li>
            <label>Category</label>
            <input type="text" />
        </li>
        <li>
            <label>Mileage</label>
            <input type="text" />
        </li>
        <li>
            <label>Engine Type</label>
            <input type="text" />
        </li>
        <li>
            <label>Seater</label>
            <input type="text" />
        </li>
        <li>
            <label>Fuel</label>
            <input type="text" />
        </li>
        <li>
            <input type="submit" />
        </li>
    </ul>
</form>

我的问题

现在表单数据很简单。我只是使用表的结构来插入数据库。我现在面临的问题是,如果类别应该是动态的,那么我该如何更改我的数据库模式才能使其具有动态性?

好的,让我定义一下我的动态视图。当管理员想要添加新的类别时,我目前所做的是创建新的类别表单,转到phpMyAdmin并添加新表,然后再添加相同的插入查询和新文件。我想通过仅使用PHP的管理面板来完成此操作。这可行吗?我应该进行哪些架构更改?


更新 #1

首先,感谢您!现在我已经改进了我的表格。现在我有了四个表:

  1. 产品 - 所有产品的索引。
  2. 类别 - 只是名义上的分类?包括类别名称及其父级。
  3. 属性 - 包括类别的属性名称。
  4. 关联 - 产品ID属性ID及其值的关联。

现在,我正在努力。这看起来很有前途。我会等待答案,同时也会更新我的工作!:) 谢谢。

2个回答

4
我认为你需要更改数据库架构。在这里,我可以看到类别是其他父类别的子类别,有n级。而且子类别具有不同的值字段。为此,您可能需要自定义字段管理,使这些字段也具有动态性。因此,我的建议架构如下所示。
产品
Product_ID, Name, Price, Photo, Category_ID (forignkey of category table)

分类

Category_ID, Name, Parent_ID

分类字段

Category_Field_ID, Category_ID, Name, Type

产品类别字段值

ID, Product_ID, Category_ID, Category_Field_ID, Value

在产品表中,我们通过Category_ID映射类别。在类别表中,我们通过parent_ID维护子类别。这意味着,如果类别是根类别,则在parent_ID中使用0,否则使用其父类别的Category_ID。在Category_Field中,使用与类别相关联的自定义字段名称。这里的类型是字段或数据的类型,例如文本、文本区域、选择、单选等。Product_Category_Field_Value用于每个产品的自定义字段值。使用它就可以了。祝一切顺利。


好的,我已经制作了你的解决方案的简洁版本!谢谢。 :) - Praveen Kumar Purushothaman

1

不要为类别的类型设置单独的表格,而应该为过滤器设置一个表格。 过滤器将具有名称/值,并且是类别的子集。 现在,假设产品只能属于一个类别,因为这简化了事情。

Product (proID, fields, catID)
Categories (catID, catName)
Filters (filID, catID, filterName)
ProductFilters (proID, filID)

您可以使用汽车电视填充分类。无论您选择哪个类别,产品只能对应其中一个,因此您应尽可能通用。然后,您可以预先设置类别的筛选器(里程燃料等)。
对于类别的正确筛选器必须在应用程序端执行而非模式上。
最后,“产品”和“筛选器”之间的链接允许您为每个筛选器名称设置值(例如里程数值,燃料值等)。您可以根据catID进行检查以确认所有相应的筛选器名称均已列出,并忽略任何具有错误catID的ProductFilters条目。
您还可以完全消除Categories,仅保留筛选器、产品及其映射,但是这样就不会为产品的可能筛选器获得额外的检查。

看起来不错,但我完全搞糊涂了。看起来很有前途。正在努力中。 :) - Praveen Kumar Purushothaman

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接