首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >数据库设计问题--解决这个问题的最佳途径

数据库设计问题--解决这个问题的最佳途径
EN

Stack Overflow用户
提问于 2019-09-18 14:14:55
回答 2查看 42关注 0票数 0

我在数据库设计方面是个新手,我正试图找到最好的方法来解决我面临的一个问题。

让我们考虑下面的示例:

想象一下,我想存储关于病人的信息,而这些病人可能患有0+疾病。

怎样才能最好地存储表格,以显示每个病人可能患上的疾病?当病人患上3种疾病时,我会感到困惑;这是如何存储在关系数据库中的呢?例如,在疾病表上没有重复的行,例如(疾病的静态数量)。

我不确定我是否在这里说得很清楚!

但假设我不认为这是有效的:

病人表- Patient_id,disease_id 1, (3,4,5,6)

任何帮助都是非常感谢的!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-09-18 14:26:00

正如注释中提到的那样,您将为此使用一个关联实体。假设你患有以下疾病:

代码语言:javascript
复制
| Disease_id | Disease_name |
-----------------------------
| 1          | Cancer       |
-----------------------------
| 2          | Leucemia     |
-----------------------------

你的病人可能像这样

代码语言:javascript
复制
| Patient_id | Patient_name |
-----------------------------
| 1          | Peter Jones  |
-----------------------------
| 2          | Mark Jacobs  |
-----------------------------

现在创建一个类似这样的表(让我们称它为ill_patients)

代码语言:javascript
复制
| Patient_id | Disease_id |
---------------------------
| 1          | 1          |
---------------------------
| 1          | 2          |
---------------------------

这意味着可怜的彼得琼斯有癌症和白血病。现在您可以像这样查询您的病人表:

代码语言:javascript
复制
SELECT patients.patient_name, diseases.disease_name
FROM (diseases INNER JOIN ill_patients ON diseases.disease_id = ill_patients.disease_id) INNER JOIN patients ON ill_patients.patient_id = patients.patient_id;

这给了你所有的病人与他们各自的疾病。

票数 4
EN

Stack Overflow用户

发布于 2019-09-18 14:28:43

病人:

代码语言:javascript
复制
patient_id, name, phone

疾病:

代码语言:javascript
复制
disease_id, name, description

Patient_Disease:

代码语言:javascript
复制
patient_id, disease_id

示例:

代码语言:javascript
复制
patient_id, name  , phone
    1     , 'jhon', '555-1234'

disease_id, name      , description
   1      , 'Cancer'  , 'Cancer is the uncontrolled development of cells.'
   2      , 'Diabetes', 'Diabetes is a disease that occurs when your blood glucose is too high.'

patient_id, disease_id
   1      ,    1
   1      ,    2

那你就可以

代码语言:javascript
复制
SELECT p.name, d.name, d.description
FROM patients p 
JOIN patient_disease pd
  ON p.patient_id = pd.patient_id
JOIN diseases d
  ON pd.disease_id = d.disease_id
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57994881

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档