DB2 V9.7 分区索引空间占用和扫描性能的描述

我们今天是要和大家一起讨论的是DB2 V9.7 分区索引空间占用和扫描性能,我们大家都知道分区表主要是应用在表比较大的背景下,所以我们使用大表才能测试出性能。下面我们创建测试表。

清单 7. 创建测试大表

  1. drop table t1;   
  2. CREATE TABLE t1   
  3. ( l_orderkey INTEGER NOT NULL, l_partkey   
  4. INTEGER, l_suppkey INTEGER, l_shipdate date, padding1 char(30)   
  5. )   
  6. PARTITION BY RANGE(l_shipdate)   
  7. (   
  8. STARTING '2008-01-01' ENDING '2008-12-31' EVERY 1 MONTH   
  9. )   
  10. ;   
  11. INSERT INTO t1 (l_orderkey, l_partkey, l_suppkey,l_shipdate,padding1)   
  12. WITH TEMP (COUNTER, l_orderkey, l_partkey, l_suppkey,l_shipdate,padding1) AS   
  13. ( VALUES (0, MOD(INT(RAND() * 12000000), 25), MOD(INT(RAND() * 12000000), 30),   
  14. MOD(INT(RAND() * 12000000), 30), DATE(MOD(INT(RAND() * 12000000), 366)+733042), 'A')   
  15. UNION ALL SELECT (COUNTER + 1), MOD(INT(RAND() * 12000000), 25),   
  16. MOD(INT(RAND() * 12000000), 30), MOD(INT(RAND() * 12000000), 30),   
  17. DATE(MOD(INT(RAND() * 12000000), 366)+733042), 'A' FROM TEMP   
  18. WHERE (COUNTER + 1) < 12000000   
  19. )   
  20. SELECT l_orderkey, l_partkey, l_suppkey,l_shipdate,padding1   
  21. FROM TEMP   
  22. ;   

 

我们创建的表包含 1200 万行数据,按照月份每个月一个分区,分区列 l_shipdate 的数据分布在’ 2008-01-01 ’和’ 2008-12-31 ’之间,且均匀分布。注意 733042 是日期 2008-01-01 在 DB2 内以天数的表达形式,是通过 days() 函数获得的。

我们首先在列 l_orderkey 上创建非DB2 V9.7 分区索引。

清单 8. 创建非分区索引

  1. db2 "Create index idx_nopart_l_orderkey on t1(l_orderkey) not partitioned"   
  2. db2 "runstats on table db2inst1.t1 and indexes all"   
  3. db2 "select substr(INDNAME,1,25) idx_name,NLEVELS,NLEAF,INDCARD   
  4. from syscat.indexes where tabname='T1'"   
  5. DX_NAME NLEVELS NLEAF INDCARD   
  6. IDX_NOPART_L_ORDERKEY 3 16831 12000000   

 

清单 8 表明,非分区索引 B 树高度为 3 层,具有 16831 个叶子页面。

清单 9. 测试非DB2 V9.7 分区索引性能

  1. db2 set current explain mode yes   
  2. db2 values current timestamp   
  3. 1   
  4. 2009-07-07-15.46.24.863000   
  5. db2 "select count(*) from t1 "   
  6. 1   
  7. ----------- 12000000   
  8. db2 values current timestamp   
  9. 1   
  10. 2009-07-07-15.46.27.394000   
  11. db2exfmt -d sample -w -1 -n % -s % -# 0 -t   
  12. Total Cost: 24109.7   
  13. Query Degree: 1   
  14. Rows RETURN ( 1) Cost I/O   
  15. | 1 GRPBY ( 2) 24109.7 17002 | 1.2e+007 IXSCAN ( 3) 23259.5 17002 | 1.2e+007   
  16. INDEX: ADMINISTRATOR   
  17. IDX_NOPART_L_ORDERKEY Q1   

 

清单 9 表明使用索引 IDX_NOPART_L_ORDERKEY 统计表 T1 的总行数时,估计总成本为 24109.7,IO 次数估计为 17002,实际花费时间为 2.45 秒。

清单 10. 创建分区索引

  1. db2 "Create index idx_part_l_orderkey on t1(l_orderkey) partitioned"   
  2. db2 "runstats on table db2inst1.t1 and indexes all"   
  3. db2 "select substr(INDNAME,1,25) idx_name,DATAPARTITIONID,NLEVELS,NLEAF,INDCARD   
  4. from syscat.indexpartitions"   
  5. IDX_NAME DATAPARTITIONID NLEVELS NLEAF INDCARD   
  6. IDX_PART_L_ORDERKEY 0 3 1134 1021133   
  7. IDX_PART_L_ORDERKEY 1 3 1062 956131   
  8. IDX_PART_L_ORDERKEY 2 3 1136 1023293   
  9. IDX_PART_L_ORDERKEY 3 3 1098 988650   
  10. IDX_PART_L_ORDERKEY 4 3 1134 1021552   
  11. IDX_PART_L_ORDERKEY 5 3 1100 990715   
  12. IDX_PART_L_ORDERKEY 6 3 1134 1020850   
  13. IDX_PART_L_ORDERKEY 7 3 1137 1023727   
  14. IDX_PART_L_ORDERKEY 8 3 1101 991839   
  15. IDX_PART_L_ORDERKEY 9 3 1133 1020225   
  16. IDX_PART_L_ORDERKEY 10 3 1078 970906   
  17. IDX_PART_L_ORDERKEY 11 3 1078 970979   

 

清单 10 表明,分区索引 idx_part_l_orderkey 具有 12 个分区,B 树高度为 3 层,合计具有 13325 个叶子页面,叶子页面数比非分区索引下降 20% 。

清单 11. 测试DB2 V9.7 分区索引性能

  1. db2 set current explain mode yes   
  2. db2 values current timestamp   
  3. 1   
  4. 2009-07-07-15.59.09.722000   
  5. db2 "select count(*) from t1 "   
  6. 1   
  7. ----------- 12000000   
  8. db2 values current timestamp   
  9. 1   
  10. 2009-07-07-15.59.11.910000   
  11. db2exfmt -d sample -w -1 -n % -s % -# 0 -t   
  12. Total Cost: 24109.7   
  13. Query Degree: 1 Total Cost: 22059.4   
  14. Query Degree: 1   
  15. Rows RETURN ( 1) Cost I/O | 1 GRPBY ( 2)   
  16. 22059.4 14178.4 | 1.2e+007 IXSCAN ( 3) 21209.2 14178.4 | 1.2e+007   
  17. INDEX: ADMINISTRATOR   
  18. IDX_PART_L_ORDERKEY Q1   

 

清单 11 表明使用索引 IDX_PART_L_ORDERKEY 统计表 T1 的总行数时,估计总成本为 22059.4,比非分区索引下降 8.5%,IO 次数估计为 14178.4,比非分区索引下降 16%, 实际花费时间为 2.19 秒,比非分区索引下降 10% 。

上述测试表明,DB2 V9.7 分区索引在空间占用、扫描性能方面比非分区索引具有一定的性能优势。

【编辑推荐】

  1. 实现DB2备份数据库的操作方案漫谈
  2. DB2归档日志的管理方案从哪几点入手?
  3. 对DB2取得当前时间的正确解析
  4. DB2性能调优中存在哪些问题,如何破解?
  5. DB2 数据类型如何才能轻松接触?

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/236056.html<

(0)
运维的头像运维
上一篇2025-04-21 20:19
下一篇 2025-04-21 20:21

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注