Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4141953
  • 博文数量: 70
  • 博客积分: 5010
  • 博客等级: 大校
  • 技术积分: 1400
  • 用 户 组: 普通用户
  • 注册时间: 2007-09-27 15:06
文章存档

2011年(2)

2010年(23)

2009年(21)

2008年(24)

我的朋友

分类:

2008-10-29 10:22:32

在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;就会执行成功了。
 
阅读(24753) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~