昨天发现近一段时间,公司某oracle库数据泵方式备份比之前慢了很多,备份集大小并未增长太多。查看了下发现该用户下存在几十万张表。

一、问题分析

1.查看用户下面的表

select count(*) from user_tables

count(*)

--   ---------

1   754583

2.按表名查看用户下的表类型数量统计

select substr(table_name, 0, 4), count(*)
from user_tables
group by substr(table_name, 0, 4)
order by count(*) desc

     SUBSTR(table_name, 0, 4)    count(*)

---------------------------------------------------------------------

1     SUME              441718
2     TEMP              209421
3     SUBR              34659
4     HP_T               3103
5     TEPT               1932
6     CITE                  163

3.查看表数量最多的分类的全名

select * from user_tables where table_name like 'SUME%'

表名可以看出后面全是随机数,所有表为空表。

二、确认及解决问题

1.确认

经过和开发确认后SUME、TEMP、SUBR这三类表是程序代码中创建并使用完临时表后没有清理操作,历史的不会再被复用。

2.解决过程

(1)程序代码最后添加清理会话创建的临时表操作。

(2)通过存储过程和JOB任务清理历史的临时表和程序补丁生效前产生的临时表。

(3)待问题解决后停用/清理JOB任务。

(2.1)存储过程

select min(created),max(created) from user_objects where object_type = 'TABLE' and object_name like 'TEMP%'

--可以先看下要清理的临时表的时间范围,看是否存在近期使用的。

--存储过程正文

create or replace procedure p_drop_temq is v_tab_name varchar(30);

cursor cur_drop_temq is select object_name from user_objects where object_type = 'TABLE' and (object_name like 'TEMP%' or object_name like 'SUME%' or object_name like 'SUBR%' ) and created < sysdate - 3;   --为了防止影响现有用户使用,清理3天之前的临时表。建议先执行查询语句确认下要清理的表,执行前做好备份。

begin

open cur_drop_temq;

loop fetch cur_drop_temq into v_tab_name;

exit when cur_drop_temq%notfound;

execute immediate 'drop table ' || v_tab_name;

end loop;

close cur_drop_temq;

end;

(2.2)创建job定时任务 实现自动调用存储过程

declare
  job number;
BEGIN
  DBMS_JOB.SUBMIT(JOB => job, /*自动生成JOB_ID*/
            WHAT => 'P_DROP_TEMQ;', /*需要执行的存储过程名称或SQL语句*/
            NEXT_DATE => sysdate, /*初次执行时间*/
            INTERVAL => 'sysdate+ 1+2/(24)' /*每天凌晨2点*/);
  commit;
end;

(2.3)通过查询系统表查看该job信息 select * from user_jobs ;

详细操作可参考文章:Oracle JOB详解

(3)JOB的停用/清理

删除JOB方法:注:BROKEN值如果为TRUE则为停用,FALSE为启用,默认FALSE。

begin

DBMS_JOB.BROKEN(JOB编号,TRUE);

dbms_job.remove(JOB编号);

commit;

end;

以下是只执行stop job的效果

begin

DBMS_JOB.BROKEN(83,TRUE);

--dbms_job.remove(JOB编号);

commit;

end;

如果需要同时删除几个job

begin

--DBMS_JOB.BROKEN(43,TRUE);

dbms_job.remove(43);

--DBMS_JOB.BROKEN(44,TRUE);

dbms_job.remove(44);

--DBMS_JOB.BROKEN(45,TRUE);

dbms_job.remove(45);

commit;

end;

Oracle 计划任务批量清理临时表实例的更多相关文章

  1. Oracle 11.2.0.4单实例打PSU,OJVM PSU补丁快速参考

    写在前面: 1.Oracel打每个补丁的操作有时存在差异,所以不管多熟悉,都应该在打任何补丁之前阅读新补丁中附带的readme. 2.Oracle每季度都会更新一个最新的PSU,本文最新指的是当前最新 ...

  2. 分享一个批量导出当前实例下的所有linkedserver脚本

    分享一个批量导出当前实例下的所有linkedserver脚本 很多时候,我们都需要导出实例下面的登录用户,job,linkedserver等等 导出job比较复杂,下午写了一个脚本把所有的linked ...

  3. 查询oracle数据库的数据库名、实例名、ORACLE_SID

    数据库名.实例名.数据库域名.全局数据库名.服务名 , 这是几个令很多初学者容易混淆的概念.相信很多初学者都与我一样被标题上这些个概念搞得一头雾水.我们现在就来把它们弄个明白. 一.数据库名 什么是数 ...

  4. oracle和mysql批量合并对比

    orm框架采用mybatis,本博客介绍一下批量合并merge用oracle和mysql来做的区别, oracle merge合并更新函数的详细介绍可以参考我以前的博客:https://blog.cs ...

  5. CLOUD清理临时表空间

    --查找空间名.物理空间路径 SELECT name, physical_nameFROM sys.master_filesWHERE database_id = DB_ID('tempdb'); 可 ...

  6. Java调用oracle存储过程通过游标返回临时表数据

    注:本文来源于 <  Java调用oracle存储过程通过游标返回临时表数据   > Java调用oracle存储过程通过游标返回临时表数据 项目开发过程中,不可避免的会用到存储过程返回结 ...

  7. Asianux 7.3安装Oracle 11.2.0.4单实例体验

    环境:Asianux 7.3 需求:安装Oracle 11.2.0.4 单实例 背景:系统使用默认的最小安装部署,Oracle安装额外需要的包统一使用yum安装. 查看当前系统相关信息: [root@ ...

  8. Nginx 负载均衡的Cache缓存批量清理的操作记录

    1)nginx.conf配置 [root@inner-lb01 ~]# cat /data/nginx/conf/nginx.conf user www; worker_processes 8; #e ...

  9. Linux平台Oracle 12.1.0.2 单实例安装部署

    主题:Linux平台Oracle 12.1.0.2 单实例安装部署 环境:RHEL 6.5 + Oracle 12.1.0.2 需求:安装部署OEM 13.2需要Oracle 12.1.0.2版本作为 ...

  10. PHP批量清理MIP-cache缓存(内附在线mipcache清理工具)

    MIP是什么?我就不多说了把. MIPCache 又是什么? 科普一下:MIPCache 是一套基于代理的 CDN 缓存系统.可用于缓存所有被某度相关页面引用或者从百度相关服务点出的 MIP 页面.当 ...

随机推荐

  1. Fiddler自动响应

    自动响应 自带了几个自动响应的规则: regex:(?inx).+.jpg$ # 以jpg结尾 这里写的是正则表达式,所以如果要拦截其他格式只需要改请求文件的后缀名即可. regex:(?inx).+ ...

  2. Windows11使用WSL Ubuntu搭建paddle的GPU环境

    Windows11使用WSL Ubuntu搭建paddle的GPU环境 最近升级到了Windows11,突然有个大胆的想法:在Windows11上安装WSL,将所有开发环境安装到WSL中.这样就能在w ...

  3. Linux系统Shell脚本第一章:Shell脚本基础及时间同步

    目录 一.Shell脚本基础 1.Shell作用 2.什么是Shell脚本及处理逻辑 3.shell脚本基本格式 4. shell脚本执行方式 5.实操演示 二.Shell脚本中的变量 1.变量的作用 ...

  4. Oralyzer-20220205

    Usage: oralyzer.py [-h] [-u URL] [-l PATH] [-crlf] [-p PAYLOAD] [--proxy] [--wayback] 可选参数: -h, --he ...

  5. 一套.NET Core +WebAPI+Vue前后端分离权限框架

    今天给大家推荐一个基于.Net Core开发的企业级的前后端分离权限框架. 项目简介 这是基于.NetCore开发的.构建的简单.跨平台.前后端分离的框架.此项目代码清晰.层级分明.有着完善的权限功能 ...

  6. Linux 第七节(LVM,网卡配置)

    LVM 逻辑卷管理器: 解决分区灵活调整大小问题 PV 物理卷 VG 卷组 LV 逻辑卷 pvcreate /dev/sdc vgcreate xiaochong  /dev/sdb /dev/sdc ...

  7. thirty-one

    动态组件 动态切换组件的显示和隐藏 如何实现动态组件的渲染 vue提供了有一个内置的<component>组件,专门用来实现动态组件的渲染.示例代码如下: 使用keep-alive保持状态 ...

  8. DELL服务器升级BIOS,做RAID磁盘阵列

    dell服务器BIOS升级.LSI集成整列卡驱动安装 1.下载启动盘rufus,安装linux系统到U盘 1.准备两个U盘,插入启动U盘进入系统,进入centos7选择页面,插入另一个U盘用于安装li ...

  9. Qt学习笔记(一) 关于QWidget类的paintEvent方法

    今天要讨论的也算是QT的核心之一了,那就是如何对widget进行重绘,这里就是可以看到,继承了QWidget的子类,自己重新写一个paintEvent函数就可以了. 这个paintEvent就相当于是 ...

  10. uniapp 样式记录

    flex https://uniapp.dcloud.io/nvue-css display: flex;/* 容器布局 */ flex:1; overflow: scroll;/* 容器内滚动条 * ...