【发布时间】:2012-04-21 06:03:34
【问题描述】:
我有 3 张桌子:
Product (shamppoo, toothpaste,..)
FrequenceOfUse (3 times/day, once/day,...)
User
您可以想象我想在数据库中存储用户使用产品的数量。这些表之间应该是什么关系?
贾维
【问题讨论】:
我有 3 张桌子:
Product (shamppoo, toothpaste,..)
FrequenceOfUse (3 times/day, once/day,...)
User
您可以想象我想在数据库中存储用户使用产品的数量。这些表之间应该是什么关系?
贾维
【问题讨论】:
User 和 Product 之间是多对多关系,FrequenceOfUse 和 UserProduct 之间是一对多关系(后者本身就是一种关系)。
请注意,对于关系是否可以独立存在关系,并没有达成共识。所以有些人更愿意将其建模为:
1-N 关系:用户 参与 使用
1-N 关系:产品 参与 使用
N-1 关系 使用 使用 频率
这两个模型都被关系建模为:
CREATE TABLE user (id INT NOT NULL PRIMARY KEY, name TEXT, ...)
CREATE TABLE product (id INT NOT NULL PRIMARY KEY, name TEXT, ...)
CREATE TABLE frequence (id NOT NULL, description TEXT, ...)
CREATE TABLE usage
(
user INT NOT NULL FOREIGN KEY REFERENCES (user),
product INT NOT NULL FOREIGN KEY REFERENCES (product),
frequence INT NOT NULL REFERENCES frequence,
PRIMARY KEY (user, product)
)
您可能会在我的博客中发现这篇文章很有用:
【讨论】:
Usage 添加代理主键。