Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2722557
  • 博文数量: 423
  • 博客积分: 7770
  • 博客等级: 少将
  • 技术积分: 4766
  • 用 户 组: 普通用户
  • 注册时间: 2006-11-09 11:58
个人简介

Oracle/DB2/Postgresql/Mysql/Hadoop/Greenplum/Postgres-xl/Mongodb

文章分类

全部博文(423)

文章存档

2019年(3)

2018年(6)

2017年(27)

2016年(23)

2015年(30)

2014年(16)

2013年(31)

2012年(73)

2011年(45)

2010年(14)

2009年(30)

2008年(30)

2007年(63)

2006年(32)

分类: DB2/Informix

2017-01-03 22:04:58


一、新建测试表空间

[db2inst1@db2 data]$ db2 "create tablespace mytbsp pagesize 4K managed by database using(file '/home/db2inst1/db2inst1/data/mydata.dbf' 100) extentsize 5 autoresize yes" 
DB20000I  SQL 命令成功完成。
[db2inst1@db2 data]$ 

二、新建测试表
[db2inst1@db2 data]$ db2 "create table mytab(name varchar(255)) in mytbsp"


三、插入测试数据
[db2inst1@db2 data]$ db2 -tsvf sevenk.sql 
insert into mytab values('ABCDEFGHIJKLMNOPQRSTUVWXYABCDEFGHIJKLMNOPQRSTUVWXYABCDEFGHIJKLMNOPQRSTUVWXYABCDEFGHIJKLMNOPQRSTUVWXY')


四、检查看表对间的大小及索引大小是否需要重组
[db2inst1@db2 data]$  db2 "select DATA_OBJECT_P_SIZE,INDEX_OBJECT_P_SIZE,REORG_PENDING,NUM_REORG_REC_ALTERS,LARGE_RIDS,RECLAIMABLE_SPACE from sysibmadm.admintabinfo where tabname='MYTAB' with ur"


DATA_OBJECT_P_SIZE   INDEX_OBJECT_P_SIZE  REORG_PENDING NUM_REORG_REC_ALTERS LARGE_RIDS RECLAIMABLE_SPACE   
-------------------- -------------------- ------------- -------------------- ---------- --------------------
                 840                    0 N                                0 Y                             0


  1 条记录已选择。

五、修改字段属性测试
[db2inst1@db2 data]$ db2 alter table mytab alter column name set not null 
DB20000I  SQL 命令成功完成。
[db2inst1@db2 data]$ db2 alter table mytab alter column name drop not null 
DB20000I  SQL 命令成功完成。
[db2inst1@db2 data]$  db2 "select DATA_OBJECT_P_SIZE,INDEX_OBJECT_P_SIZE,REORG_PENDING,NUM_REORG_REC_ALTERS,LARGE_RIDS,RECLAIMABLE_SPACE from sysibmadm.admintabinfo where tabname='MYTAB' with ur"


DATA_OBJECT_P_SIZE   INDEX_OBJECT_P_SIZE  REORG_PENDING NUM_REORG_REC_ALTERS LARGE_RIDS RECLAIMABLE_SPACE   
-------------------- -------------------- ------------- -------------------- ---------- --------------------
                 840                    0 Y                                2 Y                             0


  1 条记录已选择。

六、无法插入提示需重组
[db2inst1@db2 data]$ db2 -tsvf sevenk.sql 
insert into mytab values('ABCDEFGHIJKLMNOPQRSTUVWXYABCDEFGHIJKLMNOPQRSTUVWXYABCDEFGHIJKLMNOPQRSTUVWXYABCDEFGHIJKLMNOPQRSTUVWXY')
DB21034E  该命令被当作 SQL
语句来处理,因为它是无效的“命令行处理器”命令。在 SQL
处理期间,它返回:
SQL0668N  不允许对表 "DB2INST1.MYTAB" 执行操作,原因码为 "7"。 
SQLSTATE=57016

七、REORG组合表
[db2inst1@db2 data]$ db2 reorg table mytab
DB20000I  REORG 命令成功完成。
[db2inst1@db2 data]$  db2 "select DATA_OBJECT_P_SIZE,INDEX_OBJECT_P_SIZE,REORG_PENDING,NUM_REORG_REC_ALTERS,LARGE_RIDS,RECLAIMABLE_SPACE from sysibmadm.admintabinfo where tabname='MYTAB' with ur"


DATA_OBJECT_P_SIZE   INDEX_OBJECT_P_SIZE  REORG_PENDING NUM_REORG_REC_ALTERS LARGE_RIDS RECLAIMABLE_SPACE   
-------------------- -------------------- ------------- -------------------- ---------- --------------------
                 840                    0 N                                0 Y                             0


  1 条记录已选择。



八、查顺序查找当前表的物理大小
[db2inst1@db2 data]$ db2 -tsvf showtabsize.sql 
select  substr(t.tabschema,1,18) as tabschema , substr(t.tabname,1,40) as tabname , (DATA_OBJECT_P_SIZE + INDEX_OBJECT_P_SIZE)/1024 as tab_size_mb from    syscat.tables t join sysibmadm.admintabinfo ati on t.tabname=ati.tabname and t.tabschema=ati.tabschema where   t.type='T' and t.tabschema not like ('SYS%') order by 3 desc with ur


TABSCHEMA          TABNAME                                  TAB_SIZE_MB         
------------------ ---------------------------------------- --------------------
GZQ                T_TS_ZYRYZG_INFO                                          153
GZQ                T_TS_TZSBJB_INFO                                          113
GZQ                T_TS_ZYRYZG_INFO_TEMP                                     100
GZQ                T_TS_ZYRY_INFO                                             93
GZQ                T_TS_TZSBJB_INFO_0727                                      92
GZQ                TB_TS_ZYRY_RESULT_INFO                                     80
GZQ                CMS_ARCHIVE                                                46
GZQ                T_TS_ZYRYZ_INFO                                            25

九、查看SYSIBMADM.ADMINTABINFO 属性

点击(此处)折叠或打开

  1. [db2inst1@db2 data]$ db2 describe table SYSIBMADM.ADMINTABINFO

  2.                                 数据类型 列
  3. 列名 模式 数据类型名称 长 小数位 NULL
  4. ------------------------------- --------- ------------------- ---------- ----- ------
  5. TABSCHEMA SYSIBM VARCHAR 128 0 是
  6. TABNAME SYSIBM VARCHAR 128 0 是
  7. TABTYPE SYSIBM CHARACTER 1 0 是
  8. DBPARTITIONNUM SYSIBM SMALLINT 2 0 是
  9. DATA_PARTITION_ID SYSIBM INTEGER 4 0 是
  10. AVAILABLE SYSIBM CHARACTER 1 0 是
  11. DATA_OBJECT_L_SIZE SYSIBM BIGINT 8 0 是
  12. DATA_OBJECT_P_SIZE SYSIBM BIGINT 8 0 是
  13. INDEX_OBJECT_L_SIZE SYSIBM BIGINT 8 0 是
  14. INDEX_OBJECT_P_SIZE SYSIBM BIGINT 8 0 是
  15. LONG_OBJECT_L_SIZE SYSIBM BIGINT 8 0 是
  16. LONG_OBJECT_P_SIZE SYSIBM BIGINT 8 0 是
  17. LOB_OBJECT_L_SIZE SYSIBM BIGINT 8 0 是
  18. LOB_OBJECT_P_SIZE SYSIBM BIGINT 8 0 是
  19. XML_OBJECT_L_SIZE SYSIBM BIGINT 8 0 是
  20. XML_OBJECT_P_SIZE SYSIBM BIGINT 8 0 是
  21. INDEX_TYPE SYSIBM SMALLINT 2 0 是
  22. REORG_PENDING SYSIBM CHARACTER 1 0 是
  23. INPLACE_REORG_STATUS SYSIBM VARCHAR 10 0 是
  24. LOAD_STATUS SYSIBM VARCHAR 12 0 是
  25. READ_ACCESS_ONLY SYSIBM CHARACTER 1 0 是
  26. NO_LOAD_RESTART SYSIBM CHARACTER 1 0 是
  27. NUM_REORG_REC_ALTERS SYSIBM SMALLINT 2 0 是
  28. INDEXES_REQUIRE_REBUILD SYSIBM CHARACTER 1 0 是
  29. LARGE_RIDS SYSIBM CHARACTER 1 0 是
  30. LARGE_SLOTS SYSIBM CHARACTER 1 0 是
  31. DICTIONARY_SIZE SYSIBM BIGINT 8 0 是
  32. BLOCKS_PENDING_CLEANUP SYSIBM BIGINT 8 0 是
  33. STATSTYPE SYSIBM CHARACTER 1 0 是
  34. XML_RECORD_TYPE SYSIBM SMALLINT 2 0 是
  35. RECLAIMABLE_SPACE SYSIBM BIGINT 8 0 是
  36. XML_DICTIONARY_SIZE SYSIBM BIGINT 8 0 是





阅读(5610) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~