ora00279解决办法_oracle物化视图日志表

ora00279解决办法_oracle物化视图日志表某物化视图在增量刷新的时候报错ora-00920,尝试全量刷新的时候,报错ora-00904。BEGINDBMS_MVIEW.REFRESH(‘MV_ABCD_K_PPLLCJ’,’F’);END;ORA-12018:在创建”MYJUKKA”.”MV_ABCD_K_PPLLCJ”的代码时出现以下错误ORA-00920:无效的关系运算符ORA-06512:在”SYS.SNAPSHOT”,line…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

某物化视图在增量刷新的时候报错ora-00920,尝试全量刷新的时候,报错ora-00904。

BEGIN

DBMS_MVIEW.REFRESH(‘MV_ABCD_K_PPLLCJ’,’F’);

END;

ORA-12018:在创建”MYJUKKA”.”MV_ABCD_K_PPLLCJ”的代码时出现以下错误

ORA-00920:无效的关系运算符

ORA-06512:在”SYS.SNAPSHOT”, line 2809

ORA-06512:在”SYS.SNAPSHOT”, line 3025

ORA-06512:在”SYS.SNAPSHOT”, line 2994

ORA-06512:在line 1

SQL>

1

2

3

4

5

6

7

8

9

10

11

12

BEGIN

DBMS_MVIEW.REFRESH(‘MV_ABCD_K_PPLLCJ’,’F’);

END;

ORA-12018:在创建”MYJUKKA”.”MV_ABCD_K_PPLLCJ”的代码时出现以下错误

ORA-00920:无效的关系运算符

ORA-06512:在”SYS.SNAPSHOT”,line2809

ORA-06512:在”SYS.SNAPSHOT”,line3025

ORA-06512:在”SYS.SNAPSHOT”,line2994

ORA-06512:在line1

SQL>

BEGIN

DBMS_MVIEW.REFRESH(‘MV_ABCD_K_PPLLCJ’,’C’,ATOMIC_REFRESH=>false);

END;

ORA-12018:在创建”MYJUKKA”.”MV_ABCD_K_PPLLCJ”的代码时出现以下错误

ORA-00904:标识符无效

ORA-06512:在”SYS.SNAPSHOT”, line 2809

ORA-06512:在”SYS.SNAPSHOT”, line 3025

ORA-06512:在”SYS.SNAPSHOT”, line 2994

ORA-06512:在line 1

SQL>

1

2

3

4

5

6

7

8

9

10

11

12

BEGIN

DBMS_MVIEW.REFRESH(‘MV_ABCD_K_PPLLCJ’,’C’,ATOMIC_REFRESH=>false);

END;

ORA-12018:在创建”MYJUKKA”.”MV_ABCD_K_PPLLCJ”的代码时出现以下错误

ORA-00904:标识符无效

ORA-06512:在”SYS.SNAPSHOT”,line2809

ORA-06512:在”SYS.SNAPSHOT”,line3025

ORA-06512:在”SYS.SNAPSHOT”,line2994

ORA-06512:在line1

SQL>

查了mview的定义,直接select是没有问题,再查了mos,也没有查到相关的文档或bug,所以,决定做10046看看报错究竟出在哪里。

在10046的trace文件中,我们找到了相关报错:

PARSE ERROR #47436954909072:len=1055 dep=1 uid=147 oct=3 lid=147 tim=1442993043265145 err=920

SELECT DISTINCT LOG$.”POLNO” FROM (SELECT MLOG$.”POLNO” “POLNO” FROM “MYJUKKA”.”MLOG$_ZYX_ABCD_K_PPLLCJ” MLOG$ WHERE “SNAPTIME$$” > :1 AND (“DMLTYPE$$”!=’I’)) LOG$ WHERE (LOG$.”POLNO”) NOT IN

(SELECT MAX_TAB$.”POLNO” “POLNO” FROM (SELECT “ZYX_ABCD_K_PPLLCJ”.”POLNO” “POLNO”,”ZYX_ABCD_K_PPLLCJ”.”PARTY_NO” “PARTY_NO” …(snip)… WHERE SYS_AUDIT (CASE WHEN 1=1 THEN 1 ELSE NULL END,’MYJUKKA’,’ZYX_ABCD_K_PPLLCJ’,’MYPOLICY’,3) IS NUL) “MAS_TAB$$”

WHERE LOG$.”POLNO” = MAS_TAB$.”POLNO”)

EXEC #47436954884200:c=1063838,e=5655639,p=6341,cr=10165,cu=802,mis=0,r=0,dep=0,og=1,plh=0,tim=1442993043266925

ERROR #47436954884200:error=12018 time=1442993043266991

1

2

3

4

5

6

7

PARSEERROR#47436954909072:len=1055 dep=1 uid=147 oct=3 lid=147 tim=1442993043265145 err=920

SELECTDISTINCTLOG$.”POLNO”FROM(SELECTMLOG$.”POLNO””POLNO”FROM”MYJUKKA”.”MLOG$_ZYX_ABCD_K_PPLLCJ”MLOG$WHERE”SNAPTIME$$”>:1AND(“DMLTYPE$$”!=’I’))LOG$WHERE(LOG$.”POLNO”)NOTIN

(SELECTMAX_TAB$.”POLNO””POLNO”FROM(SELECT”ZYX_ABCD_K_PPLLCJ”.”POLNO””POLNO”,”ZYX_ABCD_K_PPLLCJ”.”PARTY_NO””PARTY_NO”…(snip)…WHERESYS_AUDIT(CASEWHEN1=1THEN1ELSENULLEND,’MYJUKKA’,’ZYX_ABCD_K_PPLLCJ’,’MYPOLICY’,3)ISNUL)”MAS_TAB$$”

WHERELOG$.”POLNO”=MAS_TAB$.”POLNO”)

EXEC#47436954884200:c=1063838,e=5655639,p=6341,cr=10165,cu=802,mis=0,r=0,dep=0,og=1,plh=0,tim=1442993043266925

ERROR#47436954884200:error=12018 time=1442993043266991

这个语句,我们直接去执行的时候,也是报错ora-920的。具体的报错是在SYS_AUDIT上,发现这个字段是放在where后面进行过滤,但是其表ZYX_ABCD_K_PPLLCJ是没有这个字段的。

另外,这个语句,所涉及到的表是ZYX_ABCD_K_PPLLCJ,而表ZYX_ABCD_K_PPLLCJ是MV_ABCD_K_PPLLCJ物化视图的基表。

所以,MV_ABCD_K_PPLLCJ物化视图的基表是ZYX_ABCD_K_PPLLCJ,而ZYX_ABCD_K_PPLLCJ在物化视图刷新时,执行了select ZYX_ABCD_K_PPLLCJ where SYS_AUDIT(case when)语句,而SYS_AUDIT字段并不存在ZYX_ABCD_K_PPLLCJ表,所以就报错ora-920了。

从名字看audit好像和审计有关,查了各种审计,发现在ZYX_ABCD_K_PPLLCJ上有FGA的细粒度审计,对ZYX_ABCD_K_PPLLCJ表的select操作进行记录。

由于SYS_AUDIT应该是在FGA审计的过程中产生,我在测试环境中,尝试刷新MV_ABCD_K_PPLLCJ表,在刷到一半的途中ctrl+c中断,再次刷新也报错了。因此怀疑一开始的报错是否也是被意外中断导致。

解决方法:disable FGA的审计策略,在全量刷新或者增量刷新,无报错。再enable FGA,问题解决。

进一步查询发现,Bug 18173440 – ORA-12018 / ORA-904 executing DBMS_MVIEW.REFRESH (Doc ID 18173440.8)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/191549.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 优惠券设计及流程_优惠券怎么设计

    优惠券设计及流程_优惠券怎么设计在整个APP开发产品发展的整个周期中,运营活动必不可少,而发放优惠券已成为运营活动的一种基本形式,而关于优惠券设计的整体流程尤为重要。接下来,分享一下自己的经验,希望对大家有帮助,感谢支持!整体架构

    2022年8月1日
    5
  • 【单调队列】数据结构之单调队列详解

    【单调队列】数据结构之单调队列详解单调队列1.初步认识单调队列是一个数据结构,并不是STL里面的内容。单调队列为何说单调,因为是队列中的元素始终保持着单增或者单减的特性。(注意始终保持这四个字)简单的sort排序就可以让一个序列有序了,为何又多此一举多出来个单调队列实现类似的功能呢?其实单调队列不只是做到了排序,还可以实现一个功能:在每次加入或者删除元素时都保持序列里的元素有序,即队首元素始终是最小值或者最大值,这个功能非常重要,单调队列我们就是使用的这个功能。举个例子:我们依次加入5个元素,分别为5,8,2,4,1那么我们假

    2022年6月25日
    20
  • windows安装mysql connector/python

    windows安装mysql connector/python参考链接

    2022年7月15日
    16
  • VB.Net程序设计:分页控件

    VB.Net程序设计:分页控件参考网络上大牛的文章,特别感谢伍华聪,分享了许多分页的文章。无论什么类型的数据库,数据量大了就需要分页,数据量大了,就要考虑分页的效率等。效率在此不做分析。分页控件支持不同类型数据库如:MSSQLServerMySQLSQLiteAccess等,只要有分页SQL语句,即可根据vb.net教程分页信息,取出相应的数据内容,再将数据内容绑定或者加工显示到UI上。分页控件需要做的事:显示页面信息。可以随意跳转到指定的页。根据页面信息返回具体的SQL分页语句。返回取出的数据内容。分页控件

    2022年9月1日
    3
  • leetcode二叉树的层次遍历_完全二叉树的中序序列

    leetcode二叉树的层次遍历_完全二叉树的中序序列LeetCode二叉树中序遍历1.1题目描述给定一个二叉树的根节点root,返回它的中序遍历。1.2示例示例:输入:root=[1,null,2,3]输出:[1,3,2]2.1解题2.1.1解题方法:递归二叉树的中序遍历方法:按照“左(子树)→中→右”顺序遍,可以使用递归方式进行遍历Java版解题/***Definitionforabinarytreenode.*publicclassTreeNode{*intval

    2022年9月14日
    2
  • windows Tasklist命令详解

    windows Tasklist命令详解“Tasklist”命令是一个用来显示运行在本地或远程计算机上的所有进程的命令行工具,带有多个执行参数。作用:结束一个或多个任务或进程。可以根据进程ID或图像名来结束进程。语法格式:TASKLIST[/Ssystem[/Uusername[/P[password]]]][/M[module]|/SVC|/V][/FIfilter][/FOformat][/NH]参数列表:/Ssystem指定连接…

    2022年5月24日
    178

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号