数据库设计问题-空外键

时间:2019-04-20 17:23:51

标签: mysql database-design

这是一个追踪费用的货运应用程序。我是后端的菜鸟,仍在学习数据库设计。

我希望能够通过费用类型(卡车,拖车,一般)以及单个卡车或拖车在前端对其进行过滤 因此,在这里,我希望仅查看卡车费用,或仅查看与#t777卡车有关的所有费用。

type  | reference  |  category    |  amount   |   date     |    
truck    t777         tires          $1,200       4-21-2019
truck    t777         inspection       $250       4-21-2019
truck    t777         heating/ac       $800       4-21-2019
truck    t4555        tires          $1,205       4-21-2019
trailer  p594         floor          $2,200       4-21-2019
general  null         tax/license    $7,000       4-11-2019

一项费用将属于卡车,拖车或一般费用。(仅一项)
一卡车可能会花很多钱
一辆拖车可能会花很多钱
一般费用可能有很多费用。

根据我的阅读,fk可以为null,但是有更好的方法来设计它吗?

我简化了表格以减少混乱。 enter image description here

tbl Truck
id

tbl Trailer
id

tbl General
id

tb Expenses<br>
id PK <br>
truck_id ( null) FK<br>
trailer_id ( null) FK<br>
general_id ( null) FK

1 个答案:

答案 0 :(得分:1)

您可能会考虑一种技术。它称为共享主键。你可以查一下。

在这种情况下,您需要第四个表“ Vehicle”(由于缺少更好的名称)。它只有一个字段ID。卡车,拖车和常规中的ID字段是车辆中相应ID的副本。声明了三个ID字段,分别是引用Vehicle表的PK和FK。当您插入新车时,您需要为此做一些额外的编程。

现在,您可以只用一个字段Vehicle_Id作为FK in Expenses。

如果可以帮助您管理数据,则可以将类型字段添加到“车辆”表中,但是如果没有该字段,则可以逃脱。