【问题标题】:MySQL Schema DBAdmins can you please look this over?MySQL Schema DBAdmins 你能看看这个吗?
【发布时间】:2012-03-04 11:07:12
【问题描述】:

数据库模式不是我的强项,但我正在制作一个食谱模式,并希望在我继续编写代码之前从专家那里获得一些意见。

InnoDB 与关系。

标签Recipe_StepsRecipe_Step_Ingredients 具有ON UPDATE RESTRICTON DELETE CASCADE 的关系设置。

好的,我重新安排了一些东西,我想我让它变得更简单而不会失去任何功能。通常食谱将成分和说明分开列出,所以我认为我不需要将步骤链接到成分。

你们怎么看?

【问题讨论】:

  • Recipe_Steps 中,您还使用 PK 来覆盖步骤序列 - 这可能会给您插入步骤带来麻烦
  • 那么你会建议我使用其他东西作为RecipeSteps的PK吗?我将如何处理与 Recipe_Step_Ingredients 和 Ingredients 的 MANY to MANY 关系?
  • 在 PK 上保留关系 - 这是它所属的位置(您可能希望将其称为 id 以与其他字段保持一致),但您可能会考虑一个额外的字段,如 step_order int not null并用 1..n 填充配方
  • 好的,我改变了一些东西你介意看一下吗?非常感谢您的帮助。
  • 我更喜欢第一个而不是第二个设计。

标签: mysql sql database-design data-modeling


【解决方案1】:

一个建议是 Recepie 步骤表与 recepie 成分无关....您可能想要这样做,因为不同的成分在不同的步骤中使用。

【讨论】:

猜你喜欢
  • 1970-01-01
  • 2010-10-07
  • 2011-08-13
  • 1970-01-01
  • 2014-09-25
  • 1970-01-01
  • 2016-03-05
  • 2018-10-11
  • 2012-10-13
相关资源
最近更新 更多