sql - CREATE VIEW 使用多个表

标签 sql oracle sql-view

您好,尝试在 oracle 中创建 View 。但是,我的代码中出现错误,我无法解决。 目前我正在尝试创建一个显示 经理,他们的名字和姓氏也分配给他们的诊所 诊所的PK和诊所地址的FK 所有地址都存储在该表中(是的,我知道这不是标准的,但这是我选择的方式) 所以我还想显示他们工作的诊所的详细地址

当然这包括两个我不确定如何实现的 WHERE 语句 第一个是 STAFFJOBNAME "MANAGER"

第二个是 ADDRESSNO 在两个表上匹配的位置

CREATE VIEW MANAGER AS
    SELECT STAFF.staffno,STAFF.staffFirstName,STAFF.staffLastName,CLINIC.clinicNo, CLINIC.addressNo
    FROM STAFF,CLINIC
    WHERE addressNo = 
    (
        SELECT addressNo, addressStreet, addressCity, addressCounty, addressPostcode, addressTelephone,
        FROM ADDRESS,
        INNER JOIN CLINIC,
        ON ADDRESS.addressNo = CLINIC.addressNo
    ) AND STAFF.staffJobName = 'MANAGER';

我也有这个版本。所以我不确定哪个更接近正确的。

CREATE VIEW MANAGER
(
    AS
    SELECT STAFF.staffno,STAFF.staffFirstName,STAFF.staffLastName,CLINIC.clinicNo, CLINIC.addressNo, ADDRESS.addressNo, ADDRESS.addressStreet, ADDRESS.addressCity, ADDRESS.addressCounty, ADDRESS.addressPostcode, ADDRESS.addressTelephone,
    FROM ADDRESS, STAFF,
    INNER JOIN CLINIC,
    ON ADDRESS.addressNo = CLINIC.addressNo
);

最佳答案

CREATE VIEW MANAGERANDCLINIC    AS
    SELECT STAFF.staffno,STAFF.staffFirstName,STAFF.staffLastName,CLINIC.clinicNo, ADDRESS.addressStreet, ADDRESS.addressCity, ADDRESS.addressCounty, ADDRESS.addressPostcode, ADDRESS.addressTelephone
    FROM STAFF,CLINIC, ADDRESS
    WHERE (CLINIC.CLINICMANAGERNO = STAFF.STAFFNO) AND
    (CLINIC.ADDRESSNO = ADDRESS.ADDRESSNO)
    ORDER BY CLINIC.CLINICNO;

终于找到了我自己问题的答案

关于sql - CREATE VIEW 使用多个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22489505/

相关文章:

sql - ORA 00936缺少表达

sql - 如何过滤查询以仅显示无法将列转换为 int 的结果

Java 读取 Oracle EXP 命令输出

sql - 如何在同一个数据库表中查找重复的列值?

c# - 检查 View 是否存在

java - JDBC 插入错误

sql - 在 postgresql 中通过 max(col) 获取行过滤

string - 在 VARCHAR 字段中使用 MAX()

sql - 在 View 中添加虚拟列

mysql - 如何使用现有字段(表的另一个字段)的一些偏移量(表的字段)在 View 中创建新字段?