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

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

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

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

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

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

需求一:

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

我们如何捕获这个需求。

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

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

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

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

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

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

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

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

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

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

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

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

相关推荐
廿一夏2 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim4 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室4 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)4 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU5 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng6 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿7 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-7 小时前
Redis 命令
数据库·redis·缓存
小江的记录本8 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`8 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存