关注“数据和云”,精彩不容错过
李培杨
云和恩墨西区交付技术顾问,有多年数据库运维经验,长期服务移动运营商行业客户,熟悉 DB2 数据库故障诊断,数据库迁移升级。
>>>
1.什么是列组织表
列组织表技术是 DB10.5 BLU 引入的新技术,按列组织的表,更加方便了复杂的查询,如果将这种表格式与星型模式数据集市配合,那么可以简化设计和调优,从而显著改进存储性能、查询性能和易用性
>>>
2.列组织表的管理方式
可以看到行组织模式的表是都是存放在一起的,而列组织模式的表是被分开保存的。
>>>
3.列存储使用环境
列存储主要适合 OLAP 类型应用,比如数据仓库系统,数据挖掘系统,决策支持系统等。这些系统有一些共同特征:数据量大,查询语句比重大,复杂的查询多。
>>>
4.如何启用列存储
官方文档上描述的是将 DB2_WORKLOAD 注册表变量设置为 ANALYTICS,更改后重启便会生效。这样做有助于配置内存、表组织、页大小和扩展数据块大小,并且会启用工作负载管理。
4.1更改环境变量
[db2inst1@enmodb2 ~]$ db2set DB2_WORKLOAD=ANALYTICS
[db2inst1@enmodb2 ~]$ db2set -all
[i] DB2_WORKLOAD=ANALYTICS
[g] DB2_COMPATIBILITY_VECTOR=MYS
[g] DB2SYSTEM=enmodb2
[g] DB2INSTDEF=db2inst1
4.2创建列组织测试表
[db2inst1@enmodb2 ~]$ db2 "create table testinfo (empno char(6),lastname varchar(15),hirdate date,salary decimal(9),comm decimal(9)) organize by column"
DB20000I The SQL command completed successfully.
用户在没有指定 organize by 的情况下可以将数据库参数 dft_table_org 设置为 COLUMN,缺省就是创建列组织表。
4.3添加数据
有选择的导出 employee 的数据。
[db2inst1@enmodb2 ~]$ db2 "export to '/home/db2inst1/export/employee.del' of del messages exp_employee.msg select empno,lastname,hiredate,salary,comm from employee"