zoukankan      html  css  js  c++  java
  • oracle错误分析:ora-04063:view view_test has errors

    百度了一下,有一个大佬是这样说的:
    在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;就会执行成功了。
     
    还有一个大佬是这样解释的:

    这个错误发生的原因有两种情况:

    1、一种是创建的视图本身有误,但是通过force等命令强制创建成功了,比如视图本身包含基表中不存在的列(或者是基于不存在的列使用了分析函数创造的列)。

    解决方案: 
    最好不要用强制方法创建视图,保证所用的列都是真实存在的!

    2、视图的基表,或者视图基于其创建的视图被删除了。Oracle中的视图可能会先被创建了,然后其基表或者视图被删除了,就会导致当前视图产生错误。比如为了避免使用占空间较多的临时表,我使用了很多视图,然后通过视图来实现复杂的取数,但我在删除视图的过程中,是按创建视图的顺序从前往后删除的。先删除的最后一个视图生成时用到过的视图,这就会导致最后一个生成的视图是基于不存在的视图产生的,从而是个错误视图,不能查询。

    解决方案: 
    所以在删除视图时,要非常注意删除的顺序,最后需要用到的数据,最好是从视图里复制到有物理存储空间的表中,再逆序删除所有的临时视图。

  • 相关阅读:
    用flask实现的分页
    用flask的扩展实现的简单的页面登录
    基于DBUtils实现数据库连接池
    Flask基础
    Flask入门
    发消息示例
    反向找related_name以及limit_fields_to
    对于stark(curd)插件的使用简单介绍
    列表的append方法和extend方法
    函数和方法的区别
  • 原文地址:https://www.cnblogs.com/swjblog/p/10286413.html
Copyright © 2011-2022 走看看