3

我正在编写一个网站,该网站允许用户发布分类广告,其中包含他们销售的不同类型商品的详细字段。但是,我有一个关于最佳数据库模式的问题。

该网站具有许多类别(例如汽车、计算机、相机),并且每个类别的广告都有自己不同的领域。例如,汽车具有门数、品牌、型号和马力等属性,而计算机具有 CPU、RAM、主板型号等属性。

现在因为它们都是列表,所以我正在考虑一种多态方法,为每个不同的类别(计算机、汽车、相机)创建一个父 LISTINGS 表和一个不同的子表。每个子表都有一个listing_id,它将链接回列表表。因此,当获取列表时,它将从 LISTINGS 中获取一行,该行由关联子表中的链接行连接。

LISTINGS
-listing_id
-user_id
-email_address
-date_created
-description

CARS
-car_id
-listing_id
-make
-model
-num_doors
-horsepower

COMPUTERS
-computer_id
-listing_id
-cpu
-ram
-motherboard_model

现在,这个模式是一个好的设计模式还是有更好的方法来做到这一点?

我考虑过单继承,但很快就打消了这个念头,因为表会变得太大太快,但随后又想到了另一个难题——如果用户对所有列表进行全局搜索,那么这意味着我将不得不查询每个孩子分开表。如果我有超过 100 个不同的类别会发生什么,会不会效率低下?

我还想到了另一种方法,其中有一个定义每个类别中的字段的主表(元表)和一个存储每个列表的字段值的字段表,但这会违反数据库规范化吗?

像 Kijiji 这样的网站是如何做到的?

4

2 回答 2

2

您的数据库设计很好。没有理由改变你所拥有的。我已经看到搜索完成了几种方式。一种是让您的搜索存储过程加入您需要搜索的所有表并索引要搜索的列。我看到它完成的第二种方法效果很好,是有一个只用于搜索的表,它获取需要搜索的任何字段的副本。然后,您将在这些字段上放置触发器并更新搜索表。

它们都有缺点,但我更喜欢第一个而不是第二个。

编辑

您需要以下表格。

类别 - ID - 描述

CategoriesListingsXref - CategoryId - ListingId

使用此交叉参考模型,您可以在搜索期间加入给定类别的所有列表。然后添加一点动态 sql(因为它更容易理解)并构建您的查询以包含您要搜索的字段并在您的查询上调用执行。

而已。

编辑 2 这似乎是一个更大的讨论,我们可以在这些评论框中找到。但是,我们将讨论的任何内容都可以通过阅读以下帖子来理解。 http://www.sommarskog.se/dyn-search-2008.html

它真的很完整,向您展示了不止一种方式来做它的优点和缺点。祝你好运。

于 2010-12-09T20:28:39.417 回答
0

我认为您选择的设计将适合您刚刚描述的场景。虽然我不确定子类表是否应该有自己的 ID。由于 CAR 是一个列表,因此这些值来自同一个“域”是有意义的。

在典型的分类广告网站中,一个广告的数据被写入一次,然后基本上是只读的。您可以利用这一点并将数据存储在第二组表中,这些表针对您希望用户搜索的方式进行了更优化的搜索。此外,搜索问题只存在于“一般”搜索中。一旦用户选择了某种类型的广告,您就可以切换到子类表以进行更高级的搜索(RAM > 4gb,cpu = overpowered)。

于 2010-12-09T20:48:48.327 回答