mysql - 数据库设计问题 - 空外键
问题描述
这是一个跟踪费用的货运应用程序。我是后端的菜鸟,仍在学习数据库设计。
我希望能够在前端按费用类型(卡车、拖车、一般)以及单个卡车或拖车对其进行过滤所以在这里我希望能够只查看卡车费用,或者仅与卡车#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 为空是可以的,但是有没有更好的方法来设计它?
我简化了表格以减少混乱。
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
解决方案
您可以考虑一种技术。它被称为共享主键。你可以查查看。
在这种情况下,您需要第四个表,称为 Vehicle(因为没有更好的名称)。它只有一个字段,ID。Truck、Trailer 和 General 中的 ID 字段是 Vehicle 中相应 ID 的副本。三个 ID 字段被声明为引用 Vehicle 表的 PK 和 FK。当您插入一辆新车时,您必须为这种情况进行一些额外的编程。
现在,您可以只使用一个字段 Vehicle_Id 作为费用中的 FK。
如果它可以帮助您管理数据,您可以将类型字段添加到 Vehicle 表中,但您可以不使用它。
推荐阅读
- sql-server - 如何获得每个季度的运行总计,而不是重复值为 0。使用 SQL Server 2012
- jenkins - 詹金斯没有检测到 Mercurial 存储库
- symfony - 如何使用返回带有状态的 json 的外部 post 调用登录 symfony
- vba - 使用 VBScript 发送电子邮件,但将已发送项目保留为未读?
- c# - 在部署目标上创建文件夹/目录
- ruby-on-rails - Searchkick 聚合或
- git - Apache 在另一个分支上无法正常工作
- c# - 本地化 ASP.NET Core 2.2 不适用于视图模型和视图
- php - 我想加快 curl 自动追随者 facebook
- sql-server - T-SQL 如果数据库不存在则创建数据库,如果存在则使用它