作者热门文章
- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
假设的例子:
我有汽车和车主。每辆汽车在给定时间属于一个(并且只有一个)车主,但所有权可以转让。车主可以在任何时候拥有零辆或多辆汽车。我想要的是将历史关系存储在 MySQL 数据库中,以便在给定任意时间时,我可以查找当前的汽车分配给车主。
即在时间 X(X 可以是现在或过去的任何时间):
在 SQL 中创建 M:N 表(带有时间戳)非常简单,但我想避免相关子查询,因为该表会变大(因此性能会受到影响)。有任何想法吗?我觉得有一种方法可以通过将这样的表与自身连接起来来做到这一点,但我对数据库的经验并不丰富。
更新:我想避免在每行中同时使用“start_date”和“end_date”字段,因为每次插入新行时都需要(可能)进行昂贵的查找。 (此外,它是多余的)。
最佳答案
创建名为 CarOwners 的第三个表,其中包含 carid、ownerid 以及 start_date 和 end_date 的字段。购买汽车时,请填写前三项并检查表格以确保没有其他人被列为车主。如果存在,则使用该数据作为结束日期更新记录。
查找当前所有者:
select carid, ownerid from CarOwner where end_date is null
寻找某个时间点的所有者:
select carid, ownerid from CarOwner where start_date < getdate()
and end_date > getdate()
getdate() 是特定于 MS SQL Server 的,但每个数据库都有一些返回当前日期的函数 - 只需替换即可。
当然,如果您还需要其他表的额外信息,您也可以加入它们。
select co.carid, co.ownerid, o.owner_name, c.make, c.Model, c.year
from CarOwner co
JOIN Car c on co.carid = c.carid
JOIN Owner o on o.ownerid = co.ownerid
where co.end_date is null
关于sql - 存储(和访问)历史记录的最佳方式是什么 1 :M relationships in a relational database?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/745242/
我是一名优秀的程序员,十分优秀!