我爱Aspx >> 数据库 >> 如何从优化SQL入手提高数据仓库的ETL效率作者:周四阳 蔡自兴
1 引言
数据仓库建设中的ETL(Extract, Transform, Load)是数据抽取、转换和装载到模型的过程,整个过程基本是通过控制用SQL语句编写的存储过程和函数的方式来实现对数据的直接操作,SQL语句的效率将直接影响到数据仓库后台的性能。
目前,国内的大中型企业基本都具有四年以上计算机信息系统应用经验,积累了大量可分析的业务数据,这些信息系统中的数据需要通过搭建数据仓库平台才能得到科学的分析,这也是近几年数据仓库系统建设成为IT领域热门话题的原因。
2 优化的思路分析
数据仓库ETL过程的主要特点是:面对海量的数据进行抽取;分时段对大批量数据进行删除、更新和插入操作;面对异常的数据进行规则化的清洗;大量的分析模型重算工作;有特定的过程处理时间规律性,一般整个ETL过程需要在每天的零点开始到6点之前完成。所以,针对ETL过程的优化主要是结合数据仓库自身的特点,抓住需要优化的主要方面,针对不同的情况从如何采用高效的SQL入手来进行。
优化的实例分析
目前数据仓库建设中的后台数据库大部分采用Oracle,以下的SQL采用Oracle的语法来说明,所有的测试在Oracle9i环境中通过,但其优化的方法和原理同样适合除Oracle之外的其他数据库。
3.1 索引的正确使用
在海量数据表中,基本每个表都有一个或多个的索引来保证高效的查询,在ETL过程中的索引需要遵循以下使用原则:
(1) 当插入的数据为数据表中的记录数量10%以上时, 首先需要删除该表的索引来提高数据的插入效率,当数据全部插入后再建立索引。
(2) 避免在索引列上使用函数或计算,在WHERE子句中,如果索引列是函数的一部分,优化器将不使用索引而使用全表扫描。举例:
低效: SELECT * ROM DEPT WHERE SAL * 12 > 25000;
高效: SELECT * FROM DEPT WHERE SAL > 25000/12;
(3) 避免在索引列上使用NOT和”!=” , 索引只能告诉什么存在于表中, 而不能告诉什么不存在于表中,当数据库遇到NOT和”!=”时,就会停止使用索引转而执行全表扫描。
(4) 索引列上用>=替代>
高效: SELECT * FROM EMP WHERE DEPTNO >=4
低效: SELECT * FROM EMP WHERE DEPTNO >3
两者的区别在于, 前者DBMS将直接跳到第一个DEPT等于4的记录而后者将首先定位到DEPTNO=3的记录并且向前扫描到第一个DEPT大于3的记录。
(5) 函数的列启用索引方法,如果一定要对使用函数的列启用索引,Oracle9i以上版本新的功能:基于函数的索引(Function-Based Index)是一个较好的方案,但该类型索引的缺点是只能针对某个函数来建立和使用该函数。
CREATE INDEX EMP_I ON EMP (UPPER( ENAME)); /*建立基于函数的索引*/
SELECT * FROM EMP WHERE UPPER(ENAME) = ‘BLACKSNAIL’; /*将使用索引*/
Ҷƪл˵?
SQL Server开发人员应聘常被问的..[04-21]
Oracle数据库系统性能优化[04-21]
深入浅出SQL教程之SELECT语句中的..[04-21]
深入浅出SQL教程之Group by和Hav..[04-21]
深入浅出SQL系列教程之SQL语言简..[04-21]
透视MySQL数据库之更新语句[04-21]
ETL学习心得:探求数据仓库关键环..[04-21]
精妙SQL语句,基础,提升,技巧[04-21]
ASP.NET2.0中Gridview中数据操作..[04-21]
用C#压缩和修复Access数据库[04-21]
Alexa算法改变:开始应对IPV6[04-21]
2006技术盘点 多项无线技术被高估[04-21]
企业SOA:“纵深防御”与“Endpo..[04-21]
分析公司关于SAP SRM以及SOA的专..[04-21]
2006年(第二届)中国客户关怀大..[04-21]
发掘SOA真正的应用价值[04-21]
没有SOA,CIO 将面临什么[04-21]
关注:六西格玛失败经验谈[04-21]
金山葛珂:政府采购要注重安全 寄..[04-21]
SQL Server开发人员应聘常被问的..[04-21]