数据库设计(火车订票系统)

为一个火车订票系统设计一个数据库是一个好的方法来训练你的数据库技巧。

其中有一些需要考虑到的复杂度。

过一些需求,并且创建表格。

为这个虚构的火车订票系统提出了10个需求。

我们将把其中每个添加到entity relational diagram(实体关系图)中来表示我们的数据库。

需求一:

一个火车在一个站点出发,在一个站点停止,在旅途中可以停靠在不同的站点。

我们如何捕获这个需求。

首先,添加一个火车站点的表格。

火车站点的表格,i像大部分的表格一样,d作为主键。

对于一个站点来说,还需要捕获什么?火车站点的名字。

需求还提到了一个火车,它代表着一个旅程。从一个地方开始,到另一个地方结束。

添加一个新的表,称为火车旅程。主键是id。

不确定还有什么需要存储进这个表中。但是现在是OK的。

现在这两个表格如何关联起来?一趟火车旅程能够有多个站点吗?

可以,我们在需求中看到了这点。

一个站点可以有多趟旅程吗?

可以假设能够,因为我们在构建一个火车预定系统。

如果错了,我们可以在后面改变它。

这是一个多对多的关系,所以我们需要一个joining table(连接表)。

相关推荐
Rverdoser19 分钟前
【SQL】多表查询案例
数据库·sql
Galeoto22 分钟前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)1 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231111 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql
喝醉酒的小白1 小时前
PostgreSQL:更新字段慢
数据库·postgresql
敲敲敲-敲代码1 小时前
【SQL实验】触发器
数据库·笔记·sql
和道一文字yyds1 小时前
MySQL 中的索引数量是否越多越好?为什么?如何使用 MySQL 的 EXPLAIN 语句进行查询分析?MySQL 中如何进行 SQL 调优?
数据库·sql·mysql
落笔画忧愁e2 小时前
FastGPT快速将消息发送至飞书
服务器·数据库·飞书
Σίσυφος19002 小时前
halcon 条形码、二维码识别、opencv识别
前端·数据库
小刘|3 小时前
深入理解 SQL 注入漏洞及解决方案
数据库·sql