ora-04063:view view_test has errors (转)

转:http://mingyue19850801.blog.163.com/blog/static/195208202010024105954696/

 

在PL/SQL中查询数据库视图时总是报告“ora-04063:view view_test has errors”的错误,在网上找了半天也不知道怎么回事,后来自己仔细分析得出结论:

Oracle视图非常强大的功能之一在于其可以创建一个带有错误的视图。比如说视图里的字段在基表里不存在,该视图仍然可以创建成功,但是非法的且无法执行。当基表里加入了该字段,或者说某个字段修改成视图里的该字段名称,那么视图马上就可以成为合法的。这个功能很有意思。

例子:

  创建基表: create table v_test (name varchar2(32),age number(12));

  创建带错误的视图:

   create force view view_test as select name,age,address from v_test;(注意加上force选项)

  由于address字段在v_test里不存在,所以会报warning: View created with compilation errors的警告,而且执行select * from view_test;时会报“ORA-04063: view "SCOTT.VIEW_TEST" 有错误”的异常。

但是如果在v_test里加上address字段,那么视图就会合法。

对基表进行修改:

 alter table v_test add (address varchar2(128));

现在再执行select * from view_test;就会执行成功了。

你可能感兴趣的:(数据库)