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

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

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

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

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

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

需求一:

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

我们如何捕获这个需求。

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

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

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

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

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

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

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

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

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

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

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

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

相关推荐
杨云龙UP10 分钟前
CentOS Linux 7 (Core)上部署Oracle 11g、19C RAC详细图文教程
数据库·oracle
ezl1fe21 分钟前
RAG 每日一技(十八):手写SQL-RAG太累?LangChain的SQL智能体(Agent)前来救驾!
数据库·人工智能·后端
小咖张27 分钟前
spring声明式事务,finally 中return对事务回滚的影响
数据库·java 声明式事务
JSON_L28 分钟前
MySQL 加锁与解锁函数
数据库·mysql
白鲸开源2 小时前
收藏!史上最全 Apache SeaTunnel Source 连接器盘点 (2025版),一篇通晓数据集成生态
大数据·数据库·开源
MonKingWD2 小时前
MySQL事务篇-事务概念、并发事务问题、隔离级别
数据库·后端·mysql
我科绝伦(Huanhuan Zhou)2 小时前
银河麒麟V10一键安装Oracle 11g脚本分享
数据库·oracle
秋千码途4 小时前
一道同分排名的SQL题
数据库·sql
秋难降6 小时前
零基础学SQL(八)——事务
数据库·sql·mysql
Starry_hello world6 小时前
MySql 表的约束
数据库·笔记·mysql·有问必答