`
chenyingjie1001
  • 浏览: 19268 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

转来一篇文章

sql 
阅读更多

 

 

 

 

DB2日常维护——REORG TABLE命令优化数据库性能

一个完整的日常维护规范可以帮助 DBA 理顺每天需要的操作,以便更好的监控和维护数据库,保证数据库的正常、安全、高效运行,防止一些错误重复发生。

由于DB2使用CBO作为数据库的优化器,数据库对象的状态信息对数据库使用合理的 ACCESS PLAN至关重要。DB2 优化器使用目录统计信息来确定任何给定查询的最佳访问方案。如果有关表或索引的统计信息已过时或者不完整,则会导致优化器选择不是最佳的方案,并且会降低 执行查询的速度。当数据库里某个表中的记录变化量很大时,需要在表上做REORG操作来优化数据库性能

一、完整的REORG表的过程

值得注意的是,针对数据库对象的大量操作,如反复地删除表,存储过程,会引起系统表中数据的频繁改变,在这种情况下,也要考虑对系统表进行REORG操作。一个完整的REORG表的过程应该是由下面的步骤组成的:

RUNSTATS ->   REORGCHK ->   REORG ->   RUNSTATS -> BIND或REBIND

注: 执行下面命令前要先连接数据库

1 RUNSTATS

   由于在第二步中REORGCHK时可以对指定的表进行RUNSTATS操作(在REORGCHK时指定UPDATE STATISTICS),所以第一步事实上是可以省略的。

2 REORGCHK

   在对表数据进行许多更改之后,逻辑上连续的数据可能会位于不连续的物理数据页上,在许多插入操作创建了溢出记录时尤其如此。按这种方式组织数据时,数据库管理器必须执行其他读操作才能访问顺序数据。另外,在删除大量行后,也需要执行其他的读操作。

表重组操作会整理数据碎片来减少浪费的空间,并对行进行重新排序以合并溢出记录,从而加快数据访问速度并最终提高查询性能。还可以指定根据特定索引来重新排序数据,以便查询时通过最少次数据读取操作就可以访问数据。

下列任何因素都可能指示用户应该重组表:

1)自上次重组表之后,对该表进行了大量的插入、更新和删除活动 。

2)对于使用具有高集群率的索引的查询,其性能发生了明显变化 。

3)在执行 RUNSTATS 命令以刷新统计信息后,性能没有得到改善。

4)REORGCHK 命令指示需要重组表(注意:在某些情况下,REORGCHK 总是建议重组表,即使在执行了重组后也是如此)。例如,如果使用 32KB 页大小,并且平均记录长度为 15 字节且每页最多包含 253 条记录,则每页具有 32700- (15 x 253)=28905 个未使用字节。这意味着大约 88% 的页面是可用空间。用户应分析 REORGCHK 的建议并针对执行重组所需的成本平衡利益。

5)db.tb_reorg_req(需要重组)运行状况指示器处于 ATTENTION 状态。此运行状况指示器的集合详细信息描述通过重组可获得好处的表和索引的列表。

REORGCHK 命令返回有关数据组织的统计信息,并且可以建议您是否需要重组特定表。然而,定期或在特定时间对目录统计信息表运行特定查询可以提供性能历史记录,该记录使用户可以发现可能具有更广性能隐含的趋势。

DB2 V9.1 引入了自动重组功能,可以对表和索引进行自动重组。自动重组通过使用 REORGCHK 公式来确定何时需要对表进行重组。它会定期评估已经更新了统计信息的表,以便了解是否需要重组。

REORGCHK命令的语法如下:

.                           -UPDATE STATISTICS--.

>>-REORGCHK--+--------------------+----------------------------->

                         '-CURRENT STATISTICS-'

            .-ON TABLE USER-----------------.

>--+-------------------------------+---------------------------><

            '-ON--+-SCHEMA--schema-name---+-'

                    | .-USER-------. |  

                    '-TABLE--+-SYSTEM-----+-'  

                       +-ALL--------+  

                       '- table-name-'

下面我们来看一下各个选项的含义:

UPDATE STATISTICS:更新表的统计数据,根据该统计数据判断是否需要重组表。

CURRENT STATISTICS:根据当前表统计数据判断是否需要重组表。

TABLE table_name:对单个表进行分析。

TABLE ALL:对数据库所有的表进行分析。

TABLE SYSTEM:对系统表进行分析。

TABLE USER:对当前用户模式下的所有表进行分析。

如果数据库中数据量比较大,在生产系统上要考虑REORGCHK的执行时间可能较长,需安排在非交易时间执行。

可以分为对系统表和用户表两部分分别进行REORGCHK:

1) 针对系统表进行REORGCHK

db2 reorgchk update statistics on table system

使用UPDATE STATISTICS参数指定数据库首先执行RUNSTATS命令。

2) 针对用户表进行REORGCHK

db2 reorgchk update statistics on table user

REORGCHK是根据统计公式计算表是否需要重整。对于每个表有3个统计公式,对索引有3个统计公式(版本8开始有5个公式),如果公式计算结果该表需重整,在输出的REORG字段中相应值为*,否则为-。

reorgchk 所使用的度量的考虑因素包括:(当查看 reorgchk 工具的输出时,找到用于表的 F1、F2 和 F3 这几列,以及用于索引的 F4、F5、F6、F7 和 F8 这几列。如果这些列中的任何一列有星号 (*),则说明当前的表和/或索引超出了阈值。)

F1: 属于溢出记录的行所占的百分比。当这个百分比大于 5% 时,在输出的 F1 列中将有一个星号 (*)。

F2: 数据页中使用了的空间所占的百分比。当这个百分比小于 70% 时,在输出的 F2 列上将有一个星号 (*)。

F3: 其中含有包含某些记录的数据的页所占的百分比。当这个百分比小于 80% 时,在输出的 F3 列上将有一个星号 (*)。

F4: 群集率,即表中与索引具有相同顺序的行所占的百分比。当这个百分比小于 80% 时,那么在输出的F4 列上将有一个星号 (*)。

F5: 在每个索引页上用于索引键的空间所占的百分比。当这个百分比小于 50% 时,在输出的 F5 列上将有一个星号 (*)。

F6: 可以存储在每个索引级的键的数目。当这个数字小于 100 时,在输出的 F6 列上将有一个星号 (*)。

F7: 在一个页中被标记为 deleted 的记录 ID(键)所占的百分比。当这个百分比大于 20% 时,在输出的 F7 列上将有一个星号 (*)。

F8: 索引中空叶子页所占的百分比。当这个百分比大于 20% 时,在输出的 F8 列上将有一个星号 (*)。

下面是执行的部分结果

db2 reorgchk update statistics on table user

执行 RUNSTATS ....

表统计信息:

F1: 100 * OVERFLOW / CARD < 5

F2: 100 * (Effective Space Utilization of Data Pages) > 70

F3: 100 * (Required Pages / Total Pages) > 80

SCHEMA    NAME                  CARD    OV    NP    FP ACTBLK    TSIZE F1 F2 F3 REORG

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

DB2INST1 STAFF                  -       -     -     -            -      -   -   - -*-

...

索引统计信息:

F4: CLUSTERRATIO 或正常化的 CLUSTERFACTOR > 80

F5: 100 * (KEYS * (ISIZE + 9) + (CARD - KEYS) * 5) / ((NLEAF - NUM EMPTY LEAFS) * INDEXPAGESIZE) > 50

F6: (100 - PCTFREE) * ((INDEXPAGESIZE - 96) / (ISIZE + 12)) ** (NLEVELS - 2) * (INDEXPAGESIZE - 96) / (KEYS * (ISIZE + 9) + (CARD - KEYS) * 5) < 100

F7: 100 * (NUMRIDS DELETED / (NUMRIDS DELETED + CARD)) < 20

F8: 100 * (NUM EMPTY LEAFS / NLEAF) < 20

 

SCHEMA   NAME                 CARD LEAF ELEAF LVLS ISIZE NDEL   KEYS F4 F5 F6 F7 F8 REORG

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

表:DB2INST1.STAFF     

DB2INST1   ISTAFF             -     -     -     -     -     -       -    -    -   -   -   - -----

...

从上面的例子来看,对于表DB2INST1.STAFF,根据统计公式F2计算结果,有必要对表进行REORG。

3、对需要重组的表进行重组(REORG TABLE)

DB2 V9 可以对表和索引进行自动重组。要进行高效率的数据访问和获得最佳工作负载性能,具有组织良好的表数据是很关键的。在对表数据进行许多更改之后,逻辑上连续 的数据可能会位于不连续的物理数据页上,在许多插入操作创建了溢出记录时尤其如此。按这种方式组织数据时,数据库管理器必须执行其他读操作才能访问顺序数 据。另外,在删除大量行后,也需要执行其他的读操作。表重组操作会整理数据碎片来减少浪费的空间,并对行进行重新排序以合并溢出记录,从而加快数据访问速 度并最终提高查询性能。还可以指定根据特定索引来重新排序数据,以便查询通过最少次数据读取操作就可以访问数据。既可重组系统目录表,也可以重组数据库 表。由 RUNSTATS 收集的统计信息与其他信息一起来显示表中的数据分布情况。特别是,通过分析这些统计信息可以知道何时需要执行哪种类型的重组。自动重组通过使用 REORGCHK 公式来确定何时需要对表进行重组。它会定期评估已经更新了统计信息的表,以便了解是否需要重组。如果需要重组,则它会在内部调度对表进行传统重组。这将要 求执行应用程序功能而不对正在重组的表进行写访问。可以使用 auto_reorg、auto_tbl_maint 和 auto_maint 数据库配置参数来启用或禁用自动重组功能部件。在分区数据库环境中,确定执行自动重组和启动自动重组是在目录分区上完成的。只需要在目录分区上启用数据库 配置参数,就将在目标表所在的所有数据库分区上运行重组。如果用户不太确定何时以及如何重组表和索引,则可以将自动重组作为整个数据库维护方案的一部分。

如果是 DB2 V8.2.2 以前的版本,是没有自动重组功能的。如果你的数据库是 DB2 V8.2.2 以前的版本,或者想在 DB2 V8.2.2 以后的版本里手工运行重组表,可以使用命令完成。手工重组可以使用 REORG 命令来完成。

以脱机方式重组表是整理表碎片的最快方法。重组可减少表所需的空间量并提高数据访问和查询性能。

必须具有 SYSADM、SYSCTRL、SYSMAINT 或 DBADM 权限,或者必须具有对表的 CONTROL 权限才能重组表。必须具有数据库连接才能重组表。标识需要重组的表之后,可以对这些表运行 REORG 实用程序,并且可以选择对在这些表上定义的任何索引运行该实用程序。

REORG TABLE命令的语法如下:

>>-REORG TABLE--table-name----+--------------------+------------>

                               '-INDEX--index-name--'

 

>-----+-----------------------+--------------------------------><

      '-USE--tablespace-name--'

 

执行REORG可以考虑分为表上有索引和没有索引两种情况:

1) 如果表上有索引

如表名为DB2INST1.STAFF,索引名为DB2INST1.ISTAFF,命令如下:

db2 reorg table db2inst1.staff index db2inst1.istaff use tempspace1

建议REORG时使用USE参数指定数据重排时使用的临时表空间,否则,REORG工作将会在表所在表空间中原地执行。

如果表上有多个索引,INDEX参数值请使用最为重要的索引名。

2) 如果表上没有索引

如表名为DB2INST1.STAFF, SYSIBM.SYSTABLES

db2 reorg table db2inst1.staff use tempspace1

db2 reorg table sysibm.systables use tempspace1

使用 REORG TABLE 命令重组 RHETTE.TEST 表

C:\> db2 reorg table rhette.test

DB20000I   REORG 命令成功完成。

要使用临时表空间 TEMPSPACE1 重组表 RHETTE.TEST,可以在 DB2CLP 窗口中使用带 USE TEMPSPACE1 选项的 REORG TABLE 命令。

使用临时表空间 TEMPSPACE1 重组 RHETTE.TEST 表

C:\> db2 reorg table rhette.test   use TEMPSPACE1

DB20000I   REORG 命令成功完成。

下面我们在示例表 TEST 上创建一个索引 A1,构建在 ID 列上。此时我们想要重组表并根据索引 A1 对行进行重新排序,可以使用带 INDEX 选项的 REORG TABLE 命令。

根据索引 A1 重组 RHETTE.TEST 表

C:\> db2 create index   a1 on rhette.test(id)

DB20000I   SQL 命令成功完成。

C:\> db2 reorg table rhette.test   index a1

DB20000I   REORG 命令成功完成。

如果想使用 SQL 调用语句重组表,请使用 ADMIN_CMD 过程发出 REORG TABLE 命令。

使用 SQL 调用语句重组 RHETTE.TEST 表

C:\> db2 call sysproc.admin_cmd ( 'reorg table rhette.test index a1' )

返回状态 = 0

要使用 DB2 管理 API 重组表,请使用 db2REORG API 。 在重组表之后,应收集有关表的统计信息,以便优化器具有最准确的数据来评估查询访问方案。另外,记住在分区数据库环境中,如果想在所有节点运行命令,需要使用 db2_all 命令。

通过删除和插入操作对表进行更新后,索引的性能会降低,其表现方式如下:

1)叶子页分段。

叶子页被分段之后,由于必须读取更多的叶子页才能访存表页,因此 I/O 操作成本会增加。

2)物理索引页的顺序不再与这些页上的键顺序相匹配(此称为不良集群索引)。

叶子页出现不良集群情况后,顺序预取操作的效率将降低,因此会导致更多的 I/O 等待。

3)形成的索引大于其最有效的级别数。

在此情况下应重组索引。

如果在创建索引时设置了 MINPCTUSED 参数,则在删除某个键且可用空间小于指定的百分比时,数据库服务器会自动合并索引叶子页。此过程称为联机索引整理碎片。但是,要复原索引集群和可用空间以及降低叶级别,请使用下列其中一种方法:

1)删除并重新创建索引。

2)使用 REORG INDEXES 命令联机重组索引。

因为此方法允许用户在重建表索引期间对表进行读写操作,所以在生产环境中可能需要选择此方法。

3)使用允许脱机重组表及其索引的选项运行 REORG TABLE 命令。

在使用 ALLOW WRITE ACCESS 选项运行 REORG INDEXES 命令时,如果同时允许对指定的表进行读写访问,则会重建该表的所有索引。进行重组时,对基础表所作的任何将会影响到索引的更改都将记录在 DB2 日志中。另外,如果有任何内部内存缓冲区空间可供使用,则还将这些更改放在这样的内存空间中。重组将处理所记录的更改以便在重建索引时与当前写活动保持同 步更新。内部内存缓冲区空间是根据需要从实用程序堆中分配的指定内存区域,它用来存储对正在创建或重组的索引所作的更改。使用内存缓冲区空间使索引重组操 作能够通过这样的方式来处理更改,即先直接从内存读取,然后读取日志(如有必要),但读取日志的时间要晚得多。在重组操作完成后,将释放所分配的内存。重 组完成后,重建的索引可能不是最佳集群的索引。如果为索引指定 PCTFREE,则在重组期间,每页上均会保留相应百分比的空间。

对于分区表,支持对各个索引进行联机索引重组和清除。要对各个索引进行重组,指定索引名:REORG INDEX index_name for TABLE table_name

对于空间索引或多维集群(MDC)表,不支持采用 ALLOW WRITE 方式的联机索引重组。

注: REORG INDEXES 命令的 CLEANUP ONLY 选项不能完全重组索引。 CLEANUP ONLY ALL 选项将除去那些标记为“删除”且被认为要落实的键。此外,它还将释放所有标记为“删除”且被认为要落实的键所在的页。在释放页后,相邻的叶子页将会合并, 前提是这样做可以在合并页上至少留出 PCTFREE 可用空间。 PCTFREE 是指在创建索引时为其定义的可用空间百分比。 CLEANUP ONLY PAGES 选项仅删除那些标记为“删除”且被认为要落实的所有键所在的页。

使用 CLEANUP ONLY 选项对分区表的索引进行重组时,支持任何访问级别。如果未指定 CLEANUP ONLY 选项,则缺省访问级别 ALLOW NO ACCESS 是唯一支持的访问级别。

REORG INDEXES 具有下列要求:

1)对索引和表具有 SYSADM、SYSMAINT、SYSCTRL 或 DBADM 权限,或者具有 CONTROL 特权。

2)用于存储索引的表空间的可用空间数量等于索引的当前大小

在发出 CREATE TABLE 语句时,考虑在大型表空间中重组索引。

3)其他日志空间

REORG INDEXES 需要记录其活动。因此,重组可能会失败,尤其是在系统繁忙和记录其他并发活动时。

注: 如果具有 ALLOW NO ACCESS 选项的 REORG INDEXES ALL 命令运行失败,则会标记索引无效并且此项操作不可撤销。但是,如果具有 ALLOW READ ACCESS 选项的 REORG 命令或具有 ALLOW WRITE ACCESS 选项的 REORG 命令运行失败,则可以复原原来的索引对象。另外还需要注意,在 DB2 V9 开放平台上对新引入的表分区功能来说,不能联机重组分区表。

4.对表和索引进行 runstats

DB2 优化器使用目录统计信息来确定任何给定查询的最佳访问方案。如果有关表或索引的统计信息已过时或者不完整,则会导致优化器选择不是最佳的方案,并且会降低 执行查询的速度。但是,决定要为给定的工作负载收集哪些统计信息是很复杂的事情,并且使这些统计信息保持最新是一项很花费时间的任务。

以往,建议对一个频繁进行大量更新、插入或者删除操作的表进行 RUNSTATS,建议在重组表之后运行 RUNSTATS 。我们都是通过手工执行 RUNSTATS 命令,或者通过 DB2 任务中心调度执行 RUNSTATS 命令来收集表的统计信息以改善数据库性能。现在 DB2 V9 又新增了自动收集统计信息功能, 自动收集统计信息通过收集最新的表统计信息来改善数据库性能。 DB2 首先确定工作负载需要哪些统计信息以及需要更新哪些统计信息,然后,在后台自动调用 RUNSTATS 实用程序以确保收集并维护正确的统计信息。然后,DB2 优化器根据准确的统计信息来选择访问方案。

从 IBM DB2 版本 9.1 开始,在创建新的数据库时,缺省情况下会启用自动收集统计信息(RUNSTATS)功能。这表示 DB2 数据库管理器将确定是否需要更新数据库统计信息。然后,RUNSTATS 实用程序会根据需要在后台自动运行,以确保最新的数据库统计信息可用。用户在创建数据库之后,可以通过将数据库配置参数 AUTO_RUNSTATS 设置为 OFF 来禁用自动收集统计信息。需要注意的是,将数据库从版本 8 迁移到版本 9.1 时,不会自动启用此功能。要在已迁移的数据库中使用此功能,必须手工进行启用。

通过使用自动统计信息收集功能,可以让 DB2 确定是否需要更新数据库统计信息。在启用了自动统计信息收集功能的情况下,DB2 将自动在后台运行 RUNSTATS 实用程序以确保最新的数据库统计信息可用.

RUNSTATS命令的语法如下:

>>-RUNSTATS ON TABLE--table-name-------------------------------->

>-----+-+--------------------------------------------------------------------+-+>

      | '-WITH DISTRIBUTION--+--------------------------------------------+--' |

      |                      '-AND--+----------+--+-INDEXES ALL--------+--'    |

      |                             '-DETAILED-' '-INDEX--index-name--'       |

      '-+--------------------------------------------------+-------------------'

        '--+-AND-+---+----------+--+-INDEXES ALL--------+--'

           '-FOR-'   '-DETAILED-' '-INDEX--index-name--'

>-----+--------------------------+-----------------------------><

      |            .-CHANGE----. |

      '-SHRLEVEL--+-REFERENCE-+--'

如果没有启用自动统计信息功能,那么我们还需要手工对需要的表和索引使用 runstats 命令,更新统计信息。比如想对 TEST 表和索引运行统计信息,发出“ runstats on table test and index all ” 。

对表 TEST 以及索引更新统计信息

C:\> db2 runstats on table rhette.test and index all

DB20000I   RUNSTATS 命令成功完成。

收集索引统计信息以允许优化器评估是否应该使用索引来解析查询。如果想收集索引统计信息,必须连接至包含表和索引的数据库并具有下列其中一个权限级别:sysadm 、sysctrl 、sysmaint 、dbadm 、对表的 CONTROL 特权 。

带 SAMPLED DETAILED 选项执行 RUNSTATS 命令需要 2MB 统计信息堆。将附加的 488 个 4K 页分配给为此附加内存需求设置的 stat_heap_sz 数据库配置参数。如果该堆看起来太小,则 RUNSTATS 在尝试收集统计信息之前会返回一条错误。

现在我们在 DB2CLP 窗口中,连上示例数据库 SAMPLE,在示例数据库中存在表 RHETTE.PROJECT,其有两个索引 PK_PROJE CT 和 XPROJ2,我们要创建索引 PK_PROJE CT 和 XPROJ2 的详细统计信息,可以发出带 AND DETAILED INDEXES ALL 选项的 RUNSTATS 命令。创建索引 PK_PROJECT 和 XPROJ2 的详细统计信息

C:\> db2 RUNSTATS ON TABLE rhette.project AND DETAILED

INDEXES ALL DB20000I   RUNSTATS 命令成功完成。

命令成功完成。如果我们想创建两个索引的详细统计信息,但是不想耗费太多的资源和时间,可以使用采样的方式而不是对每个索引条目执行详细计算。

创建索引 PK_PROJECT 和 XPROJ2 的详细统计信息,使用采样方式

C:\> db2 RUNSTATS ON TABLE rhette.project AND SAMPLED DETAILED

INDEXES ALL DB20000I   RUNSTATS 命令成功完成。

命令成功完成。如果要创建索引上的详细采样统计信息以及表的分布统计信息,以便索引和表统计信息一致,可以使用带 WITH DISTRIBUTION 选项的 RUNSTATS 命令。

收集表 rhette.project 的详细统计信息

C:\> db2 RUNSTATS ON TABLE rhette.project

WITH DISTRIBUTION ON KEY COLUMNS AND SAMPLED

DETAILED INDEXES ALL DB20000I   RUNSTATS 命令成功完成。

命令成功完成。如果想全面收集表和索引的信息,而不是使用抽样的方式收集表 rhette.project 的详细统计信息

C:\> db2 RUNSTATS ON TABLE rhette.project WITH DISTRIBUTION

AND DETAILED INDEXES ALL DB20000I   RUNSTATS 命令成功完成。

5 (可选) 上面命令完成后可以重复第二步,检查REORG的结果,如果需要,可以再次执行REORG和RUNSTATS命令。

6 BIND或REBIND

RUNSTATS命令运行后,应对数据库中的PACKAGE进行重新联编,简单地,可以使用db2rbind命令来完成。

 

db2rbind命令的语法如下:

>>-db2rbind--database--/l logfile----+------+------------------->

                                     '-all--'

                                       .-conservative--.

>-----+-------------------------+--/r--+-any-----------+-------><

      '-/u userid--/p password--'

例如,如果数据库名为SAMPLE,执行:

db2rbind sample -l db2rbind.out

二、DB2 V8.2 如何配置AUTO_RUNSTATS

1.配置参数

首先确保DBM参数HEALTH_MON是ON,

然后使用如下命令打开AUTO_RUNSTATS 的开关。

db2 update db cfg using AUTO_MAINT ON AUTO_TBL_MAINT ON AUTO_RUNSTATS ON

2.设置需要自动RUNSTATS的表的profile,该profile会纪录于系统表sysibm.systables的STATISTICS_PROFILE列

例如:

db2 runstats on table huangdk.hasales and indexes all tablesample system(20) set profile only                                              

说明:a.RUNSTATS的语法见《命令指南》

          http://publib.boulder.ibm.com/in ... c/core/r0001980.htm

          b.tablesample 是采样runstats的选项,例子里采用system的方法,采样20%

3.AUTO_RUNSTATS触发条件

配置完后,需要重起一下实例,然后系统会在第一次连接请求时,去触发AUTO_RUNSTATS,如果表需要RUNSTATS,就开始RUNSTATS。

以后,系统每隔3小时触发AUTO_RUNSTATS

用户可以使用以下语句检查:

db2 select STATS_TIME,SUBSTR(STATISTICS_PROFILE,1,200) from sysibm.systables

其中,STATS_TIME列指示最后一次RUNSTATS的时间。

另外,db2diag.log里有这样的信息:

2004-10-27-16.08.39.007000+480 I30117H327         LEVEL: Event

PID     : 2596                 TID : 3404        PROC : db2fmp.exe

INSTANCE: DB2                  NODE : 000

FUNCTION: DB2 UDB, Automatic Table Maintenance, db2HmonEvalStats, probe:100

START   : Automatic Runstats: evaluation has started on database TBCSAMPL

指示自动RUNSTATS已经运行。

 

三、优化语句的批量获取

1、查找数据库管理表空间(DMS)

SELECT TBSpace FROM syscat.tablespaces WHERE TBSpaceType = 'D' ;

2、DMS下的creator(用户、模式)

SELECT DISTINCT creator

FROM sysibm.systables

WHERE tbspace IN (SELECT TBSpace FROM syscat.tablespaces WHERE TBSpaceType = 'D' );

'DB2ADMIN'

3、creator下的表数量

SELECT creator,count(1)

FROM sysibm.systables

WHERE Type = 'T' AND tbspace IN (SELECT TBSpace FROM syscat.tablespaces WHERE TBSpaceType = 'D')

GROUP BY creator ;

--'DB2ADMIN'    56

4、构造优化脚本

--=============================================================================

(1).reorgchk update statistics on table SCHEMA.TABLE ;

select 'reorgchk update statistics on table DB2ADMIN.'||rtrim(name)||';' from sysibm.systables where creator = 'DB2ADMIN' AND Type = 'T' AND tbspace IN (SELECT TBSpace FROM syscat.tablespaces WHERE TBSpaceType = 'D')

--=============================================================================

(2).reorg table SCHEMA.TABLE ;

select 'reorg table DB2ADMIN.'||rtrim(name)||';' from sysibm.systables where creator = 'DB2ADMIN' AND Type = 'T' AND tbspace IN (SELECT TBSpace FROM syscat.tablespaces WHERE TBSpaceType = 'D')

--=============================================================================

(3).reorg indexes all for table SCHEMA.TABLE ;

select 'reorg indexes all for table DB2ADMIN.'||rtrim(name)||';' from sysibm.systables where creator = 'DB2ADMIN' AND Type = 'T' AND tbspace IN (SELECT TBSpace FROM syscat.tablespaces WHERE TBSpaceType = 'D'

--=============================================================================

(4).runstats on table SCHEMA.TABLE and indexes all;                                                      

select 'runstats on table DB2ADMIN.'||rtrim(name)||' and indexes all;'

from sysibm.systables

where creator = 'DB2ADMIN' AND

      Type = 'T' AND

    tbspace IN (SELECT TBSpace FROM syscat.tablespaces WHERE TBSpaceType = 'D') ;

--=============================================================================

 

 

0
10
分享到:
评论

相关推荐

    对一篇文章进行按单词统计后哈弗曼编码解码

    在这个项目中,首先需要对一篇文章进行单词统计。这通常涉及到读取文本文件,然后将内容分割成单词。在Java中,可以使用`BufferedReader`类读取文件,`String.split()`方法进行单词切分,并使用哈希表(如`HashMap`...

    程序员们必读的一篇好文章

    根据描述及部分内容可以看出,“程序员们必读的一篇好文章”很可能也强调了自我驱动性和责任感对于程序员来说极其关键。这表现在对工作的热情投入、面对困难时不轻易放弃等方面。拥有强烈责任感的程序员会更加专注于...

    统计一篇文章中每个单词的个数

    总结来说,统计一篇文章中每个单词的个数涉及到文本读取、预处理、分词、词频统计以及可能的可视化展示等多个步骤。这个过程可以使用各种编程语言实现,而"Statistical words.exe"作为一个小程序,很可能是为了简化...

    李笑来185篇范文-考博TOFEL英语作文

    通过仔细研究《李笑来185篇范文-考博TOEFL英语作文》中的每一篇文章,考生可以深入理解上述知识点,并逐步提高自己的写作水平,以期在考试中取得理想的成绩。这不仅对于考博过程中的TOEFL考试至关重要,也对未来的...

    AI玩转公众号流量主,公众号爆文保姆级教程,一篇文章收入2000+

    最近随着公众号改版,公众号流量主爆火,很多人纷纷入局 ,都想赚一波风口上的钱。 有人问:公众号流量主,现在真的是风口项目吗? 从目前来看,确实是。...只要出了爆文就是钱,随便一篇10万+的文章,打底收入2000+

    分享一篇petri网入门文章

    1. "基于Petri网B/S体系架构的在线评测系统建模与验证.pdf" - 这篇文章可能讨论如何使用Petri网来建模和验证基于浏览器/服务器(B/S)架构的在线评测系统,确保其正确性和性能。 2. "基于Petri 网的语义Web 服务...

    一年级我的家作文锦集7篇.docx

    第一篇作文描述了一个名为"滨河公园"的地方,提到了公园中的石碑、草坪、树木、池塘、假山和凉亭,展现了公园的美丽景色,并表达了作者对家乡公园的热爱。 第二篇作文介绍了作者的家乡——湖北仙桃,提到了市镇府...

    一年级我的家作文三篇.docx

    3. **人物描写技巧**:第一篇作文通过具体事例展示了父亲的辛勤工作和母亲的勤劳付出,这是通过动作和行为来刻画人物性格的方法,是人物描写的初步尝试。 4. **情感表达与幽默元素**:文中“我”的角色以幽默的方式...

    一年级作文大全【通用8篇】.docx

    1. **观察与描写**:第一篇作文讲述了作者理发的经历,展示了如何细致地描述个人感受和环境,这在写作中是非常重要的技巧,包括对情绪、动作和周围环境的描绘。 2. **故事叙述**:第二篇作文以熊猫为主题,讲述了...

    一篇关于开方算法fpga实现的文章

    标题中的“一篇关于开方算法FPGA实现的文章”暗示了我们即将探讨的是如何在Field-Programmable Gate Array(FPGA)上实现平方根计算的算法。FPGA是一种可编程逻辑器件,允许用户根据需求定制硬件电路,常用于高性能...

    俄罗斯方块游戏,虽然没有源代码,但是有一篇文章详细的讲解了制

    在这个项目中,虽然没有提供完整的源代码,但有一篇文章详细介绍了如何制作这个游戏。这为对游戏编程感兴趣的人提供了一次学习的机会,特别是对于那些想要了解游戏开发基础的人来说,这是一个很好的实践项目。 描述...

    一篇基于机器学习的网页恶意代码检测方法研究文章

    本文将深入探讨一篇基于机器学习的网页恶意代码检测方法的研究文章,该方法旨在通过对抗样本学习和模型训练提高检测的准确性。 文章首先介绍了网页恶意代码的背景和危害,强调了对这类威胁进行有效检测的重要性。...

    了解MBSE,这一篇文章就够了

    基于模型的系统工程(MBSE)作为未来工业研发数字化的重要...不管未来这些技术人员来自哪个方向,在最初接触MBSE这一概念的时候,都不可避免的要了解这一领域方方面面的概念和知识,来实现“入门”。鉴于此,特将近期做

    PECL转TTL TTL转PECL 电平转换传输芯片

    本篇文章将深入解析一款名为MC10ELT28/D与MC100ELT28的电平转换传输芯片。该芯片集成了PECL到TTL以及TTL到PECL的双向电平转换功能,适用于发送与接收跨背板信号的应用场景。通过详细介绍其技术参数、特点及应用领域...

    转篇文章关于progress控件的使用

    在本文中,我们将深入探讨如何使用ProgressBar(进度条)控件,特别是基于文章"转篇文章关于progress控件的使用"的内容。ProgressBar控件在Windows Forms、WPF、Android、iOS以及许多其他开发平台中都有应用,尽管...

    15篇贯通6级词汇文章

    从给定的文件信息来看,我们探讨的是一篇英文阅读材料,标题为“15篇贯通6级词汇文章”,这表明文章集旨在帮助学生通过学习这些文章来掌握和运用大学英语六级所需的词汇量。六级英语在中国的教育体系中是高等教育...

    【小学生作文】小学生照片里的故事作文600字四篇.doc

    第一篇作文中,作者描述了一张在方特游玩时拍摄的照片,回忆了与父母在“转转杯”游乐设施中的欢乐时光。文章通过生动的叙述,让读者感受到了家庭的温馨和游乐场的刺激与乐趣。作者通过细节描绘,如爸爸在游戏后的...

    统计英文文章字母

    本程序采用C++语言实现,旨在提供一个简单的方法来统计一篇文章中各个字母的出现次数,并计算出它们在文章中所占的比例,即每个字母的概率。 首先,我们要了解C++的基本语法和数据结构。在这个程序中,可能会使用到...

    【小学生作文】小学生美丽的景物作文【五篇】.doc

    第一篇作文以澄池为主题,描绘了一个月牙形的人工湖。作者通过细致的观察,描述了湖边的柳树、银杏树、芭蕉树和亭子,以及池中的芦苇和金鱼,营造出一幅宁静而美丽的画面。文章中引用了古诗,展现了文学的运用,增强...

    统计一篇txt文档(英文)中各英文字母出现的次数及概率

    ` 来打开指定的文件。 - **打开模式**:`ios::in` 表示以输入模式打开文件;`ios::out` 表示以输出模式打开文件。 - **关闭文件**:通常在文件使用完毕后,应关闭文件,可以通过 `infile.close();` 和 `outfile....

Global site tag (gtag.js) - Google Analytics