我有一份表格(除其他事项外),询问病人是否有某些健康状况,以及他/她的父母是否有/是否有过某些健康状况。在关系数据库中存储这些信息的最佳方法是什么?
为了便于讨论,让我们考虑一种单一的健康状况,糖尿病。请注意,我至少有25个条件要记录。
我考虑了两种可能的解决方案,但我对两者都不满意。
1.使用带有以下字段的检查表:
PatientId -- integer
Diabetes -- boolean
DiabetesFather -- boolean
DiabetesMother -- boolean这里的问题是,字段的数量爆炸了;对于每个条件,我有3个字段。
2.使用包含以下字段的条件表
PatientOrPatientParentId -- integer
Diabetes -- boolean在这种情况下,病人的父母必须作为假病人引入DB。
发布于 2016-09-25 19:49:29
有许多可能的解决方案,问题中列出的解决方案的一个替代方案是使用三个表对其进行建模,如下所示:
Patients (PatientId (PK), PatientName, ...)
-- example: 1, "Patient1"
Conditions (ConditionID (PK), ConditionName, ...)
-- example: 1, "Diabetes"
PatientCond (PatientID (FK), ConditionID (FK), PatientStatus, FatherStatus, MotherStatus)
-- example: 1, 1, true, false, true使用连接表是建模多到多关系的通用解决方案。
https://stackoverflow.com/questions/39691026
复制相似问题