- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个名为 Receipt 的数据库表,如下所示:
列
是单独的表
限制条件是对于每张收据,上述任何收据都不能超过一张。这意味着对于每张收据,将有一个付款条目、一个发票条目、一个自定义字段和组织条目。
现在我认为我可以摆脱上面提到的所有列名,而是将 _id 关联为我的收据表的主键,并将相同的 _id 关联为所有其他表的外键。
在上面的结构中,我也很困惑,如果我使用上面的结构,我应该如何为 - payment - invoice - custom_field - organization 生成唯一值。但是,如果我选择后者,则主键和外键将自动生成并且是唯一的。我也担心编辑。有什么有用的建议吗?
下面是我的结构:
最佳答案
Jordi 是对的,他说对了。只是我不认为多对多关系适用于原始问题,因为它说“不能不止一个......”
The constraint is that for each receipt there cant be more than one of any from the above. Which means for each receipt there will be one payment entry, one invoice entry, one custom_field and organization entry.
因此,对于每张收据:
一次付款。
一张发票。
一个自定义字段
等等,根据需要对收据表进行尽可能多的“扩展”。
如果我理解正确,您可以在纯理论中将所有这些列放入一个包含许多列的“大”表中,这在实践中当然会很丑陋且不好,因为其他原因可能是题外话。但请注意,如果您只有一个表,那么所有内容都会有相同的主键,这似乎是您要求的,但也可能不是您真正想要的。
如果你想将这种“唯一的大表”非规范化为收据、发票、自定义字段等...那么收据表将有一个主键(比如说“ID”)以及任何“扩展名”子表将有它们的主键(也可以说是“ID”)。
所以我们开始:
Receipt.ID、Invoice.ID、CustomFields.ID、Payment.ID 等等...
请记住,所有这些 ID 都与收据相关。 Invoice.ID 和 Receipt.ID 在任何方面都不需要相同。
将这些子项中的任何一个“绑定(bind)”到其父项“Receipt”所需的是一个专用列(假设为“ReceiptID”),它是 Receipt.ID 的外键。
现在,作为最后一步,如果您在子表中的 ReceiptID 上定义了一个 UNIQUE KEY 或 UNIQUE INDEX,它将确保对于任何给定的收据,您最多有 1 笔付款、最多 1 张发票等。
例如,如果将来您需要为您的收据获取多个自定义字段,或多个付款信息,您只需将自定义字段表中的 UNIQUE 约束更改为一个简单的非唯一 INDEX,然后您完成了。
由于声誉低,我无法发布图片。我希望我能够阐明我的观点。
关于sql - 对如何在我的场景中应用外键概念感到困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32067708/
websocket的用途/场景 先总结:高即时性服务,比如聊天室的群聊,server顺序收到了张三,李四的消息,立即就推送给王五,不能让王五等半天。 Ajax也可以一秒一刷,让王五去问张三说话没,如果
前端的工作过程里,本地开发、提供测试环境,总得有个用着顺手的服务器软件,这个场景里nginx很流行。 介绍两个好用的配置项:rewrite try_files @xxxx rewrite 比较
我有一个场景的两个不同角度的 2 个视频文件,我想重建场景的 3D 估计。它类似于 3D 传感器的作用(例如 Kinect、PrimeSense)。我正在寻找一个库,甚至是一个完善的机器视觉算法,以便
我已阅读RebaseProject页面并尝试了一个不平凡的例子(不是对一个完整的分支进行 rebase )。这与 rebase D 的情况类似我场景B。 这是rebase之前的情况: default
有没有办法将我的场景保存在 JavaFx 应用程序中单独的 Java 文件中?我尝试过这样的事情: public class MyApp extends Application { pri
我有这样的场景:用户想要查看大量有关自己的信息。例如:年龄、姓名、地位、收入、工作、爱好、 child 的名字、妻子的名字、酋长的名字、祖父/祖母的名字。大约 50 个变量。他可以选择任何变量来显示信
我希望有人能帮助我解决这个问题:我有一个包含条目的表。我想执行查询并根据模式获取得分最高的记录。模式将是:如果我的话按原样出现,那么该条目的分数将是最高的。如果该单词出现在句子中,则该条目的分数将低于
我正在尝试在我的应用程序委托(delegate)方法中实现一些逻辑。了解当前正在运行哪种场景将非常有帮助。 [[CCDirector sharedDirector] runningScene] 返回当
好的,这是一个有趣的。我有 2 个表:tbl_notes、tbl_notes_categories 简单地说,tbl_notes 有一个 categoryid,我将 2 个表与该 ID 相关联。所以,
我有一个使用并行运行的 Specflow、selenium、NUnit 的测试解决方案在 AssemblyInfo 中添加了这个:[程序集:Parallelizable(ParallelScope.F
我正在尝试弄清楚如何在 SpriteKit 中添加更多场景。如果我在 GameViewController 中使用 SpriteKit 生成的行 if let scene = GameScene.un
目录 1、业务背景 2、场景分析 3、流程设计 1、业务流程 2、导入流程
我是 Unity 的新手,所以修复起来可能非常简单。我使用了一个 3D Google SketchUp 模型,我想让玩家环顾模型。 super 简单。 我添加了 3D 平面,添加了相机并更新了设置以支
我需要标记要跳过的某些测试。但是,有些测试是参数化的,我只需要能够跳过某些场景。 我使用 py.test -m "hermes_only" 调用测试或 py.test -m "not hermes_o
我已经开始使用 SpecFlow 并想知道是否可以在规范之间重用场景 基本上我的想法是这样的(我可能从根本上是错误的:)) 我编写了一项功能来验证导航。 功能:导航 I should be able
在编写验证输入表单上的信息的 BDD 场景时,您将如何列出规则。 选项是: 1) 每个规则一个场景 2)场景大纲,每个领域和规则的例子 我们如何说某些不在特定字符集中的无效内容,例如: 鉴于我输入了一
我们如何使用 StoryQ 来测试预期出现异常的场景? 最佳答案 就实际代码而言,在测试代码的 .Then 部分,您需要创建一个 Action 或 Func 来确定正在测试的内容,然后在代码的 .Th
完成快速初学者努力通过点击按钮向场景添加节点。 我知道我可以使用点击手势来获取点击坐标并执行点击测试,然后在点击的 3D 空间中放置一个对象。但是,我想在设备屏幕的中央显示一个球体或十字准线,当点击屏
如何在表格中传递空格? Background: Given the following books |Author |(here several spaces)
我正在尝试从 Eric Haines' Standard Procedural Database (SPD) 渲染“mount”场景,但折射部分就是不想配合。我已经尝试了所有我能想到的方法来修复它。
我是一名优秀的程序员,十分优秀!