您可以通过将每个表中的id用作主键和引用另一个表中的id的外键来确保1-1对应。这是允许的,并且保证1-1’。
有时,您需要这样的表,但是一个表的行数要少于另一个表。当存在子集关系并且您不希望所有行上都有其他列时,会发生这种情况。
另一个目的是将单独的列存储在不同的位置。当我了解数据库时,这种方法称为 垂直分区
。如今,柱状数据库相对普遍。这些将概念带到了极致–每列都有一个单独的“存储”(尽管“存储”并不完全是“表”)。
你为什么要这样做?原因如下:
- 您不经常使用的列不想在较频繁的列上为每个查询加载。
- 您具有经常更新的列,并且不想锁定其余的列。
- 您有太多列无法存储在一行中。
- 您在不同的列上有不同的安全要求。
Postgres确实提供了其他可能与您相关的机制。特别地,表继承在您的情况下可能很有用。
所有这些,您通常不会设计这样的数据库。这样做有充分的理由,但是更常见的是将与实体相关的所有列都放在同一张表中。



