ora-04063:view view_test has errors (转)

本文介绍了在Oracle数据库中如何创建带有错误的视图,并通过示例展示了如何解决因视图引用了基表中不存在的字段而导致的ORA-04063错误。通过使用FORCE选项创建视图,即使字段不存在也能创建成功,但执行时会报错。一旦基表中添加了这些字段,视图即可正常工作。

转: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;就会执行成功了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值