暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 19C 从临时表加载计划

原创 Asher.HU 2021-02-04
1041


您可能需要将最佳计划从源数据库转移到其他目标数据库。

例如,您可能已经在测试数据库上调查了一组计划,并确认它们表现良好。然后,您可能希望将这些计划加载到生产数据库中。

临时表是一个表,在存在该表的过程中,它会存储计划,以便在您解压缩计划时这些计划不会从表中消失。使用以下DBMS_SPM.CREATE_STGTAB_BASELINE步骤创建登台表。要打包(插入行)和从打包表中解包(从中提取行),请使用PACK_STGTAB_BASELINEUNPACK_STGTAB_BASELINE功能DBMS_SPMOracle数据泵导入和导出使您能够将登台表复制到其他数据库。

图28-3从临时表加载计划


使用软件包PACK_STGTAB_BASELINE功能导出计划DBMS_SPM,然后使用导入它们UNPACK_STGTAB_BASELINE下表描述了一些功能参数。

表28-8 PACK_STGTAB_BASELINE和UNPACK_STGTAB_BASELINE参数

功能参数描述

table_name

指定要导入或导出的表。

origin

SQL计划基线的来源。这些过程接受所有可能的值DBA_SQL_PLAN_BASELINES.ORIGIN作为origin参数。例如,origin参数允许MANUAL-LOAD-FROM-STSMANUAL-LOAD-FROM-AWRMANUAL-LOAD-FROM-CC

本教程假定以下内容:

  • 您要创建一个stage1在源数据库中命名的登台表
  • 您要将用户拥有的所有计划加载spm到登台表中。
  • 您要将转移表转移到目标数据库。
  • 您想要将计划stage1作为固定计划加载

要将一组SQL计划基准从一个数据库转移到另一个数据库:

  1. 使用适当的特权将SQL * Plus连接到源数据库,然后使用该CREATE_STGTAB_BASELINE过程创建临时表

    以下示例创建一个名为的登台表stage1

    BEGIN
      DBMS_SPM.CREATE_STGTAB_BASELINE (
        table_name => 'stage1');
    END;
    /
    
    复制
  2. 在源数据库上,将要从SQL管理库导出的SQL计划基准打包到暂存表中。

    以下示例将用户创建的启用的计划基准打包spm到登台表中stage1使用计划名称(plan_name),SQL句柄(sql_handle)或任何其他计划条件选择SQL计划基准table_name参数是强制性的。

    DECLARE
      v_plan_cnt NUMBER;
    BEGIN
      v_plan_cnt := DBMS_SPM.PACK_STGTAB_BASELINE (
        table_name => 'stage1'
    ,   enabled    => 'yes'
    ,   creator    => 'spm'
    );
    END;
    /
    
    复制
  3. stage1使用Oracle Data Pump Export 将登台表导出到转储文件中。
  4. 将转储文件传输到目标数据库的主机。
  5. 在目标数据库上,stage1使用Oracle Data Pump Import实用程序从转储文件中导入登台表
  6. 在目标数据库上,将SQL计划基线从登台表解压缩到SQL管理库中。

    以下示例解压缩存储在登台表中的所有固定计划基准的包装stage1

    DECLARE
      v_plan_cnt NUMBER;
    BEGIN
      v_plan_cnt := DBMS_SPM.UNPACK_STGTAB_BASELINE (
        table_name => 'stage1'
    ,   fixed      => 'yes'
    );
    END;
    /
    复制

也可以看看:

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论

P
暂无图片
获得了6次点赞
暂无图片
内容获得1次评论
暂无图片
获得了18次收藏
目录