查看引用相同主键的多个外键的视图/查询

时间:2016-05-29 03:39:50

标签: sql database derby

您好我有两张桌子,风险表中的staff_id用于查找所有者和联系人的姓名。我想知道是否可以创建一个包含所有者姓名和员工姓名的视图。我试图创建一个如下所示的视图,但我只能在视图中包含所有者名称或联系人姓名。 (作为参考,我使用德比)。提前谢谢。

CREATE VIEW public_view AS
SELECT r.risk_id, r.risk_name s.staff_name
FROM risk r, staff s
AND r.owner_id = s.staff_id;


CREATE TABLE STAFF
(
    staff_id varchar(8) NOT NULL,
    staff_name varchar(100),
    staff_email_addr varchar(30),
    staff_position varchar(30),
    staff_sect_elem varchar(60),
    CONSTRAINT pk_staff_id PRIMARY KEY (staff_id)
);

CREATE TABLE RISK
(
    risk_id varchar(6) NOT NULL, 
    risk_name varchar(20) NOT NULL,
    risk_desc varchar(20),
    owner_id varchar(8),
    contact_id varchar(8),
    CONSTRAINT pk_risk_id PRIMARY KEY (risk_id),
    CONSTRAINT fk_owner_id FOREIGN KEY (owner_id) REFERENCES STAFF(staff_id), 
    CONSTRAINT fk_contact_id FOREIGN KEY (contact_id) REFERENCES STAFF(staff_id) 
);

3 个答案:

答案 0 :(得分:0)

使用表别名:

select *
from RISK r
LEFT OUTER JOIN STAFF o ON r.owner_id = o.staff_id
LEFT OUTER JOIN STAFF c ON r.contact_id = c.staff_id

答案 1 :(得分:0)

你很亲密。您需要使用连接创建一个包含来自两个表的数据的表,在这种情况下连接到fk:

CREATE VIEW public_view AS
SELECT r.risk_id, r.risk_name s.staff_name
FROM risk r
LEFT JOIN staff s
ON r.owner_id = s.staff_id;

左连接不会提取Staff表中的数据,但不会提取Risk表中的数据。

答案 2 :(得分:0)

这就是我最终做的事情

CREATE VIEW public_view1 (risk_id, risk_name, owner_name, contact_name) AS
SELECT r.risk_id, r.risk_name, o.staff_name, c.staff_name
FROM risk r
LEFT OUTER JOIN staff o ON r.owner_id = o.staff_id
LEFT OUTER JOIN staff c ON r.contact_id = c.staff_id;