gpt4 book ai didi

mysql - SQL数据透视表中的外键——数据库设计

转载 作者:行者123 更新时间:2023-11-30 23:00:51 24 4
gpt4 key购买 nike

我正在使用 DBDesigner 4 来设计我的数据库关系。

我有一个users 表和一个recipes 表。一个用户可以拥有多个食谱,但一个食谱不能被多个用户拥有。该关系由图片中的 user_recipes 关系显示。 (从 usersrecipes 的一对多关系)。

但是,食谱可以被用户喜欢。许多用户可以喜欢许多食谱。这是 usersrecipes 之间的多对多关系,其数据透视表是 users_like_recipes

但是当我创建这个数据透视表时,我只需要 users_idrecipes_id 列。 recipes_users_id 列是自己添加的,我无法删除它。它说第三列来自模型中定义的另一个关系。我猜它是 user_recipes 关系。

当我删除 user_recipes 关系时,我得到了我想要的数据透视表。

但我也需要 user_recipes 关系!

请。任何帮助将不胜感激。

最佳答案

我建议从食谱表中删除 user_id 作为主键。目前 if id 和 user_id 的组合为您的食谱表提供标识。在这种情况下,多个 user_id 可以创建相同的配方 ID,因为组合必须是唯一的。 user_id 可以只是表中的普通列。如果你真的想要,你可以在 (id, user_id) 上创建一个备用键,但你不需要它,因为 id 是唯一的。

关于mysql - SQL数据透视表中的外键——数据库设计,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24105772/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com