为一个火车订票系统设计一个数据库是一个好的方法来训练你的数据库技巧。
其中有一些需要考虑到的复杂度。
过一些需求,并且创建表格。
为这个虚构的火车订票系统提出了10个需求。
我们将把其中每个添加到entity relational diagram(实体关系图)中来表示我们的数据库。
需求一:
一个火车在一个站点出发,在一个站点停止,在旅途中可以停靠在不同的站点。
我们如何捕获这个需求。
首先,添加一个火车站点的表格。
火车站点的表格,i像大部分的表格一样,d作为主键。
对于一个站点来说,还需要捕获什么?火车站点的名字。
需求还提到了一个火车,它代表着一个旅程。从一个地方开始,到另一个地方结束。
添加一个新的表,称为火车旅程。主键是id。
不确定还有什么需要存储进这个表中。但是现在是OK的。
现在这两个表格如何关联起来?一趟火车旅程能够有多个站点吗?
可以,我们在需求中看到了这点。
一个站点可以有多趟旅程吗?
可以假设能够,因为我们在构建一个火车预定系统。
如果错了,我们可以在后面改变它。
这是一个多对多的关系,所以我们需要一个joining table(连接表)。