簡體   English   中英

如何連接多個表並打印在單行中填充多個表的相同 id 的結果

[英]How to join multiple tables and printing the result for same id which are populating more than one in a single row

CREATE TABLE details_1 (
    e_id    NUMBER(10),
    e_name  VARCHAR2(30),
    CONSTRAINT pk_details_1_e_id PRIMARY KEY ( e_id )
);

insert into details_1 values(11,'A');


CREATE TABLE ques_ans (
    ques_ans_id  NUMBER(10),
    ref_ques_id  NUMBER(10),
    ref_ans_id   NUMBER(10),
    e_id         NUMBER(10),
    CONSTRAINT pk_ques_ans PRIMARY KEY ( ques_ans_id ),
    CONSTRAINT fk_ques_ans FOREIGN KEY ( e_id )
        REFERENCES details_1 ( e_id ),
        constraint fk_ques_and_ques_id foreign key(ref_ques_id)
        references ques_ref (ques_id)
);

insert into ques_ans values(1,3,1,11);
insert into ques_ans values(2,2,2,11);
insert into ques_ans values(3,4,1,11);

CREATE TABLE ques_ref (
    ques_id     NUMBER(10),
    code        VARCHAR2(50),
    code_label  VARCHAR2(100),
    constraint pk_ques_ref primary key(ques_id)
);

insert into ques_ref values(3,'changes_exist','Any known changes');
insert into ques_ref values(2,'E_Clubbed','E_id clubbed with other');
insert into ques_ref values(4,'E_impacted','E impacted by other');

CREATE TABLE ans_ref (
    ref_ans_id  NUMBER(10),
    code        VARCHAR2(10),
    code_value  VARCHAR2(30)
);

insert into ans_ref values(1,'R_Yes','Yes');
insert into ans_ref values(2,'R_No','No');

加入表格面臨的問題:

表 ques_ans 具有從 ques_ref 表填充的 ref_ques_id 列。 因此,如果 ref_ques_id = 3 和 ref_ans_id = 1 那么它應該顯示“是”,即從 ans_ref 表中填充。 同樣,對於 ref_ques_id = 2,它應該顯示“否”,對於 ref_ques_id = 4 也是如此。

我的嘗試:

select d.e_id, qa.ref_ques_id,
ar.code_value

from details_1 d
join ques_ans qa on(d.e_id = qa.e_id)
join ans_ref ar on(ar.ref_ans_id = qa.ref_ans_id) ;

在我的嘗試中,我得到了 3 行,但理想情況下,output 應該像截圖中所附的那樣。

預期產出

列 e_id:來自 details_1 表

Column Changes_exist:在 ques_ans 表 ref_ques_id 列中驗證並基於 ref_ans_id 打印 Yes 或 no。

E_clubbed 列:在 ques_ans 表 ref_ques_id 列中驗證並基於 ref_ans_id 打印是或否。

列 E_Impacted:在 ques_ans 表 ref_ques_id 列中驗證並基於 ref_ans_id 打印是或否。

output 應該像隨附的屏幕截圖一樣,但我卡住了如何將其打印在一行中

工具:SQL 開發者版本:20.4

您編寫的代碼幾乎可以做到; 缺少另一個連接(帶有ques_ref ),以便您提取代號,但這仍然不能“修復”它,因為 - 據我所知 - 在 SQL 中無法“動態地”執行它。 我們通常做的是pivot數據。 一種選擇是使用聚合 function (在本例中為max )和case表達式,並按字面意思命名每一列(使用您之前提取的代碼名稱,但只是為了在編寫列的別名時有所幫助)。

SQL> with temp as
  2    (select d.e_id, qa.ref_ques_id, qr.code, ar.code_value
  3     from details_1 d
  4     join ques_ans qa on d.e_id = qa.e_id
  5     join ans_ref ar on ar.ref_ans_id = qa.ref_ans_id
  6     join ques_ref qr on qr.ques_id = qa.ref_ques_id
  7    )
  8  select e_id,
  9    max(case when ref_ques_id = 3 then code_value end) changes_exist,
 10    max(case when ref_ques_id = 2 then code_value end) e_clubbed,
 11    max(case when ref_ques_id = 4 then code_value end) e_impacted
 12  from temp
 13  group by e_id;

      E_ID CHANGES_EXIST   E_CLUBBED       E_IMPACTED
---------- --------------- --------------- ---------------
        11 Yes             No              Yes

SQL>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM