您当然可以在另一个视图的基础上建立一个视图:
create table my_table (id number, name varchar2(20), address varchar2(30));table MY_TABLE created.create or replace view my_view_1 asselect id, namefrom my_table;view MY_VIEW_1 created.create or replace view my_view_2 asselect mv1.id, mv1.name, mt.addressfrom my_view_1 mv1join my_table mt on mt.id = mv1.id;view MY_VIEW_2 created.
但是您不能引用基础表中的任何内容,包括不属于视图的任何字段:
create or replace view my_view_3 asselect mv1.id, mv1.name, mv1.addressfrom my_view_1 mv1join my_table mt on mt.id = mv1.id;SQL Error: ORA-00904: "MV1"."ADDRESS": invalid identifier00904. 00000 - "%s: invalid identifier"
具有相同列的基础表不是问题,并且如果您在视图中包含的内容超过,则无论如何都必须为其别名。
有时您可能会遇到性能问题,如果您针对相同的基表创建新视图并将其扩展为包含所需的额外数据,则可能会更快,更可靠(尽管可能更难维护)。



