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

views/ queries for multiple foreign keys referencing same primary keys

你好,我有两个table,来自风险table的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) 
);

使用table别名:

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

你很接近。您需要使用连接从两个 table 中的数据创建一个 table,在本例中是在 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 table 中但不在 Risk table 中的数据。

这就是我最后做的事情

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;