2
Hospital_Visit
      hid pid HospitalName DoctorId
      41   1  abc        1
      42   2  xyx        2

Patient_Master
       pid  PatientName
       1        jill
       2        rosy
Doctor_Master
      DoctorID DoctorName
       1        John
       2        Jack
Hospital_Study
      sid  hid  exam  status
       1    41   jjj   sfvn
       2    41   fks   jdjd

select  Hospital_Visit.Pid,PatientName,DoctorName from Patient_Master
inner join Hospital_Visit on Hospital_Visit.pid=Patient_Master.pid
inner join Doctor_Master on Doctor_Master.DoctorID= Hospital_Visit.DoctorID
inner join Hospital_Study on Hospital_Study.hid=Hospital_Visit.hid

Pid PatientName  DoctorName exam status
1   Jill         John       jjj  sfvn
2   rosy         John       fks   jdjd

**

//Correct output i want
    Pid PatientName  DoctorName exam status
    1   Jill         John       jjj  sfvn
    2   rosy         Jack       fks   jdjd

**

inner join由于隐藏在 Hospital_Visit 和 Hospital_Study 上,我得到了错误的结果重复医生姓名
我该如何解决这个问题


(DTU 编辑 - 可用形式的当前样本数据):

create table Hospital_Visit(hid int,pid int,HospitalName char(3), DoctorId int)
insert into Hospital_Visit(hid, pid, HospitalName, DoctorId) values
      (41,   1,  'abc',        1),
      (42,   2,  'xyx',        2)

create table Patient_Master(pid int,  PatientName char(4))
insert into Patient_Master(pid,  PatientName) values
       (1,        'jill'),
       (2,        'rosy')
create table Doctor_Master(DoctorID int, DoctorName char(4))
insert into Doctor_Master(DoctorID, DoctorName) values
       (1,        'John'),
       (2,        'Jack')
create table Hospital_Study(sid int, hid int,  exam char(3),  status char(4))
insert into Hospital_Study(sid,  hid,  exam,  status) values
       (1,    41,   'jjj'   ,'sfvn'),
       (2,    41,   'fks'   ,'jdjd')
4

2 回答 2

0

使用现在给出的示例数据(修订版 4),不可能获得您想要的输出。

现在,您的查询返回以下内容:

Pid PatientName DoctorName
1   jill        John
1   jill        John

你想要的是这样的:

//Correct output i want
Pid PatientName  DoctorName exam status
1   Jill         John       jjj  sfvn
2   rosy         Jack       fks   jdjd

...但Hospital_Study表中的数据与此不匹配,因为两行都有hid = 41

Hospital_Study
  sid  hid  exam  status
   1    41   jjj   sfvn
   2    41   fks   jdjd

所以他们都引用了Hospital_Visit表中的第一行,该行属于名为“Jill”的患者。
--> 有了这个数据,不可能选择名为“rosy”的患者,因为Hospital_Study表中没有引用 rosy 就诊(hid = 42)的行。

要获得所需的输出, 中的数据Hospital_Study需要如下所示:

Hospital_Study
  sid  hid  exam  status
   1    41   jjj   sfvn
   2    42   fks   jdjd
        /\
        ||
        this is different

有了这些数据,以及您问题的确切查询,您将得到以下结果:

Pid PatientName DoctorName
1   jill        John
2   rosy        Jack
于 2012-08-03T14:07:55.293 回答
-2

我对你的加入有疑问

inner join Hospital_Study on Hospital_Study.hid=Hospital_Visit.hid

Hospital_Study.hid 是正确的外键,但 Hospital_Visit.hid 是主键还是外键。

如果 Hospital_Visit.hid 是外键,那么您必须在医院的主表 (Hospital_Master) 上再添加一个内部连接。

于 2012-08-03T12:59:34.623 回答