删除Oracle分区存储过程_绿色软件之家

绿色软件之家:您身边最放心的安全下载站! 最新更新|软件分类|软件专题|手机版|系统之家|纯净系统

您当前所在位置:首页数据库Oracle → 删除Oracle分区存储过程

删除Oracle分区存储过程

时间:2015/6/28来源:绿色软件之家作者:网管联盟我要评论(0)

  CREATE OR REPLACE PROCEDURE "PRO_MESSAGE_DELETE"

  is

  names     varchar2(1024);    --分区名称

  dates     varchar2(1024);  --分区日期

  temp    varchar2(1024);

  v_temp   varchar2(1024);

  v_sql   varchar2(1024);

  v_cs    varchar2(1024);

  v_error varchar2(1024);

  TYPE t_ref_cursor IS REF CURSOR;

  c t_ref_cursor;

  --获取分区列表

  begin

  v_cs := 'select PARTITION_NAME,HIGH_VALUE

  from USER_TAB_PARTITIONS

  where TABLE_NAME = upper(''us_internalinfo_back'')';

  open c for v_cs;

  fetch c

  into names,dates;

  while c% found loop

  --分区时间

  v_temp := 'select to_char('||dates||',''yyyy-MM-dd'') from dual';

  execute immediate v_temp into temp ;

  --时间比较

  if (months_between(trunc(sysdate,'mm'),trunc(to_date(temp,'yyyy-mm-dd'),'mm'))>=3)

  then

  ---删除分区

  -- dbms_output.put_line(temp);

  v_sql := 'alter table us_internalinfo_back truncate partition ' ||names;

  execute immediate v_sql;

  end if;

  --取下一条数据

  fetch c  into names,dates;

  end loop;

  close c;

  commit;

  exception

  when others then

  v_error := sqlcode || ' - ' || sqlerrm;

  dbms_output.put_line(v_error);

  rollback;

  end PRO_MESSAGE_DELETE;

关键词标签:Oracle

相关阅读

文章评论
发表评论

热门文章 Oracle中使用alter table来增加,删除,修改列Oracle中使用alter table来增加,删除,修改列oracle中使用SQL语句修改字段类型-oracle修oracle中使用SQL语句修改字段类型-oracle修使用低权限Oracle数据库账户得到管理员权限使用低权限Oracle数据库账户得到管理员权限Oracle对user的访问控制Oracle对user的访问控制

相关下载

人气排行 ORACLE SQL 判断字符串是否为数字的语句Oracle中使用alter table来增加,删除,修改列的语法ORACLE和SQL语法区别归纳(1)oracle grant 授权语句如何加速Oracle大批量数据处理Oracle删除表的几种方法ORACLE修改IP地址后如何能够使用Oracle 10g创建表空间和用户并指定权限