oracle 重新编译用户无效对象

oracle sys用户无效对象

select owner,object_name
, replace(object_type,‘ ‘,‘‘) object_type
,to_char(created,‘yyyy-mm-dd‘) as created
,to_char(last_ddl_time,‘yyyy-mm-dd‘) as last_ddl_time,
status
from dba_objects where status=‘INVALID‘ and owner=‘SYS‘;

OWNER   OBJECT_NAME           OBJECT_TYPE    CREATED     LAST_DDL_TIME  STATUS
------  --------------------- -------------  ----------- -------------- ----------
SYS     ALL_TAB_STATISTICS    VIEW           2011-09-17  2012-05-16     INVALID
SYS     USER_TAB_STATISTICS   VIEW           2011-09-17  2012-05-16     INVALID
SYS     ALL_IND_STATISTICS    VIEW           2011-09-17  2012-05-16     INVALID
SYS     USER_IND_STATISTICS   VIEW           2011-09-17  2012-05-16     INVALID
SYS     VALIDATE_ORDIM        PROCEDURE      2011-09-17  2012-05-16     INVALID
SYS     DBMS_CUBE_ADVISE      PACKAGEBODY    2011-09-17  2012-05-16     INVALID
SYS     DBMS_CUBE             PACKAGEBODY    2011-09-17  2012-05-16     INVALID

方法1:手动重新rebuilt

SQL>alter view sys.ALL_TAB_STATISTICS  compile; 

SQL>alter view sys.USER_TAB_STATISTICS compile;
 
SQL>alter view ALL_IND_STATISTICS      compile;
 
SQL>alter view sys.USER_IND_STATISTICS compile;

SQL>alter procedure sys.VALIDATE_ORDIM   compile;

SQL>alter package DBMS_CUBE_ADVISE compile body;
  
SQL>alter package DBMS_CUBE  compile body;

方法2:
oracle用户下执行

$cd $ORACLE_HOME/rdbms/admin
$sqlplus  /  as sysdba
SQL>@utlprp.sql

编译完成后,再次查看

SQL> select owner,object_name
  2  , replace(object_type,‘ ‘,‘‘) object_type
  3  ,to_char(created,‘yyyy-mm-dd‘) as created
  4  ,to_char(last_ddl_time,‘yyyy-mm-dd‘) as last_ddl_time,
  5  status
  6  from dba_objects where status=‘INVALID‘ and owner=‘SYS‘;

no rows selected         
                                                                                                                                                                                                                                                                                                                     方法3:
以下是一个转帖的方法
                                                                                                                           
--创建自动编译失效过程事务记录表
declare
  tabcnt integer := 0;
begin
  select count(*) into tabcnt from dba_tables where table_name=‘RECOMPILE_LOG‘;
  if tabcnt = 0 then
    execute immediate ‘create table recompile_log(rdate date,errmsg varchar2(200))‘;
  end if;
end;
/
 
--创建编译失效对象的存储过程
create or replace procedure recompile_invalid_objects  
as
  str_sql varchar2(200);  --中间用到的sql语句
  p_owner varchar2(20);   --所有者名称,即SCHEMA
  errm varchar2(200);     --中间错误信息
begin
  /*****************************************************/
  p_owner := ‘owner‘;/***用户名*************************/
  /*****************************************************/ 
  insert into recompile_log(rdate, errmsg) values(sysdate,‘time to recompile invalid objects‘); 
   
  --编译失效存储过程
  for invalid_procedures in (select object_name from all_objects
    where status = ‘INVALID‘ and object_type = ‘PROCEDURE‘ and owner=upper(p_owner))
  loop
    str_sql := ‘alter procedure ‘ ||invalid_procedures.object_name || ‘ compile‘;
    begin
      execute immediate str_sql;
    exception
      When Others Then
      begin
        errm := ‘error by obj:‘||invalid_procedures.object_name||‘ ‘||sqlerrm;
        insert into recompile_log(rdate, errmsg) values(sysdate,errm);
      end;
    end;
  end loop;
   
  --编译失效函数
  for invalid_functions in (select object_name from all_objects
    where status = ‘INVALID‘ and object_type = ‘FUNCTION‘ and owner=upper(p_owner))
  loop
    str_sql := ‘alter function ‘ ||invalid_functions.object_name || ‘ compile‘;
    begin
      execute immediate str_sql;
    exception
      When Others Then
      begin
        errm := ‘error by obj:‘||invalid_functions.object_name||‘ ‘||sqlerrm;
        insert into recompile_log(rdate, errmsg) values(sysdate,errm);
      end;
    end;
  end loop;
 
  --编译失效包
  for invalid_packages in (select object_name from all_objects
    where status = ‘INVALID‘ and object_type = ‘PACKAGE‘ and owner=upper(p_owner))
  loop
    str_sql := ‘alter package ‘ ||invalid_packages.object_name || ‘ compile‘;
    begin
      execute immediate str_sql;
    exception
      When Others Then
      begin
        errm := ‘error by obj:‘||invalid_packages.object_name||‘ ‘||sqlerrm;
        insert into recompile_log(rdate, errmsg) values(sysdate,errm);
      end;
    end;
  end loop;
   
  --编译失效类型
  for invalid_types in (select object_name from all_objects
    where status = ‘INVALID‘ and object_type = ‘TYPE‘ and owner=upper(p_owner))
  loop
    str_sql := ‘alter type ‘ ||invalid_types.object_name || ‘ compile‘;
    begin
      execute immediate str_sql;
    exception
      When Others Then
      begin
        errm := ‘error by obj:‘||invalid_types.object_name||‘ ‘||sqlerrm;
        insert into recompile_log(rdate, errmsg) values(sysdate,errm);
      end;
    end;
  end loop;
 
  --编译失效索引
  for invalid_indexs in (select object_name from all_objects
    where status = ‘INVALID‘ and object_type = ‘INDEX‘ and owner=upper(p_owner))
  loop
    str_sql := ‘alter index ‘ ||invalid_indexs.object_name || ‘ rebuild‘;
    begin
      execute immediate str_sql;
    exception
      When Others Then
      begin
        errm := ‘error by obj:‘||invalid_indexs.object_name||‘ ‘||sqlerrm;
        insert into recompile_log(rdate, errmsg) values(sysdate,errm);
      end;
    end;
  end loop;
 
  --编译失效触发器
  for invalid_triggers in (select object_name from all_objects
    where status = ‘INVALID‘ and object_type = ‘TRIGGER‘ and owner=upper(p_owner))
  loop
    str_sql := ‘alter trigger ‘ ||invalid_triggers.object_name || ‘ compile‘;
    begin
      execute immediate str_sql;
    exception
      When Others Then
      begin
        errm := ‘error by obj:‘||invalid_triggers.object_name||‘ ‘||sqlerrm;
        insert into recompile_log(rdate, errmsg) values(sysdate,errm);
      end;
    end;
  end loop;
  
end;
/
 
--创建任务计划,每天早上8点整执行该任务,且保证此任务有且只有一个
declare 
  jobcnt integer :=0;
  job_recompile number := 0;
  str_sql varchar2(200);
begin 
  select count(*) into jobcnt from all_jobs where what = ‘recompile_invalid_objects;‘ and broken = ‘N‘;
  if jobcnt > 0 then
    for jobs in (select job from all_jobs where what = ‘recompile_invalid_objects;‘ and broken = ‘N‘)
    loop
      str_sql := ‘begin dbms_job.remove(‘||jobs.job||‘); end;‘;
      begin
        execute immediate str_sql;
      exception
        When Others Then null;
      end;
    end loop; 
  end if;
  --创建任务计划
  dbms_job.submit(job_recompile,‘recompile_invalid_objects;‘,sysdate,‘TRUNC(SYSDATE + 1) + 8/24‘);
  --启动任务计划
  dbms_job.run(job_recompile);
end;
/

oracle 重新编译用户无效对象

时间: 2024-08-08 17:52:30

oracle 重新编译用户无效对象的相关文章

转://oracle 重新编译用户无效对象

select owner,object_name, replace(object_type,' ','') object_type,to_char(created,'yyyy-mm-dd') as created,to_char(last_ddl_time,'yyyy-mm-dd') as last_ddl_time,status from dba_objects where status='INVALID' and owner='SYS'; OWNER OBJECT_NAME OBJECT_T

Oracle编译用户无效对象

在采用IMPDP/IMP工具迁移数据时,经常会提示无效对象的警告,需要采用如下方式处理. 1. 查询指定用户的无效对象 su – oracle sqlplus / as sysdba SQL> select owner,object_name,replace(object_type,' ','') object_type,to_char(created,'yyyy-mm-dd') as created,to_char(last_ddl_time,'yyyy-mm-dd') as last_ddl

处理Oracle数据中的无效对象

今天还原了一份数据库(在服务器上没有无效对象),还原在本地之后有三十几个无效对象,当时很是郁闷,然后我发现还原之后的数据库中缺少表! 开始我怀疑Oracle数据库的还原功能,但是在我创建表的时候发现,原来是我本地数据库中表空间和服务器上的不一致.然后我在网上找到了解决方案: select username, default_tablespace from dba_users where username='NAXZXXBM';--查找某用户的默认表空间alter tablespace USERS

oracle统计某个用户的对象个数

--统计某个用户下面的对象个数 --包括表,视图,同义词,函数,存储过程,包,触发器,索引,约束,序列. SELECT (SELECT COUNT(*) FROM USER_TABLES) AS TABLES, (SELECT COUNT(*) FROM USER_VIEWS)AS VIEWS, (SELECT COUNT(*) FROM USER_SYNONYMS)AS SYNONYMS, (SELECT COUNT(*) FROM USER_OBJECTS WHERE OBJECT_TYPE

oracle 清空当前用户所有对象

1 BEGIN 2 FOR REC IN 3 (SELECT OBJECT_NAME,OBJECT_TYPE FROM USER_OBJECTS 4 WHERE OBJECT_TYPE='PROCEDURE' 5 OR OBJECT_TYPE='TABLE' 6 OR OBJECT_TYPE='VIEW' 7 OR OBJECT_TYPE='FUNCTION' 8 OR OBJECT_TYPE='PACKAGE' 9 OR OBJECT_TYPE='SEQUENCE' 10 ) 11 LOOP

Oracle 用户、对象权限、系统权限

--================================ --Oracle 用户.对象权限.系统权限 --================================  一.用户与模式 用户:对数据库的访问,需要以适当用户身份通过验证,并具有相关权限来完成一系列动作 SYS用户,缺省始终创建,且未被锁定,拥有数据字典及其关联的所有对象 SYSTEM用户,缺省始终创建,且未被锁定,可以访问数据库内的所有对象 模式(schema):是某个用户拥有所有对象的集合.具有创建对象权限并创建

oracle重新编译失效对像

重新编译失效对像可执行utlrp.sql文件: SQL> @?/rdbms/admin/utlrp.sql TIMESTAMP -------------------------------------------------------------------------------- COMP_TIMESTAMP UTLRP_BGN 2016-08-24 13:04:49 DOC> The following PL/SQL block invokes UTL_RECOMP to recom

oracle系列(二)oracle体系结构和用户管理

博主QQ:819594300 博客地址:http://zpf666.blog.51cto.com/ 有什么疑问的朋友可以联系博主,博主会帮你们解答,谢谢支持! 在使用oracle之前,我们一定要对oracle的体系结构有深入的理解,与之前我们学习过的sqlserver体系结构是不一样的,所以对于我们来说是一个全新的内容. 一.oralce体系结构 1.概述 Oracle的体系结构是数据库的组成,工作过程,以及数据库中数据的组织与管理机制,要了解oracle数据库的体系结构,就必须要理解oracl

01-查询Oracle中所有用户信息

[[email protected] ~]# su - oracle [[email protected] ~]$ sqlplus /nolog SQL*Plus: Release 10.2.0.1.0 - Production on Tue Jul 8 21:47:01 2014 Copyright (c) 1982, 2005, Oracle.  All rights reserved. SQL> conn /as sysdba; Connected. 查询Oracle中所有用户信息 1.查