日期:2013-09-28  浏览次数:20530 次

如何构建银行数据仓库
河南省邓州市新华东路11号市人行 宋玉长

数据仓库技术作为一项数据管理领域的新技术,其精髓在于针对联机分析处理(OLAP)提出了一种综合的处理方案,与以往很多技术不同的是,它次要是一种概念,在此概念指点下完成系统的结构。既没有可以直接购置到的现成产品,也没有具体的分析规范和实现方法,也就是说没有成熟、可靠且被广泛接受的数据仓库标准。在以往关系数据库的设计和实现中,不只要详细的理论推导,还有无数的设计实例,无论你使用的是什么公司的数据库产品、开发工具,只需按照规范做,那么实现同一业务需求的方案都会很类似。而现无数据仓库的实现中,出现了MOLAP方案和ROLAP方案的区别,出现了五花八门的数据仓库建模工具、表现工具,而设计人员的团体经验和素质也会在其中扮演很重要的角色。数据仓库技术的实现方式目前在数据仓库技术的实际使用中次要包括如下几种具体实现方式。1、在关系数据库上建立数据仓库(ROLAP)2、在多维数据库上建立数据仓库(MOLAP)MOLAP方案是以多维方式来组织数据,以多维方式来存储数据;ROLAP方案则以二维关系表为核心表达多维概念,通过将多维结构划分为两类表:维表和理想表,使关系型结构能较好地顺应多维数据的表示和存储。在多维数据模型的表达方面,多维矩阵比关系表更清晰且占用的存储更少,而通过关系表间的连接来查询数据的ROLAP系统,系统功用成为最大问题。MOLAP方案比ROLAP方案要简明,索引及数据聚合可以自动进行并自动管理,但同时丧失了一定的灵活性。ROLAP方案的实现较为复杂,但灵活性较好,用户可以动态定义统计和计算方式,另外能保护在已有关系数据库上的投资。由于两种方案各有优劣,因此在实际使用中,往往将MOLAP和ROLAP结合使用,即所谓的混合模型。利用关系数据库存储历史数据、细节数据或非数值型数据,发挥关系数据库技术成熟的优势,减少花费,而在多维数据库中存储当前数据和常用统计数据,以提高操作功用。3、在原有关系库上建立逻辑上的数据仓库由于目前正在运转的OLTP系统中曾经积累了海量数据,如何从中提取出决策所需的有用信息就成为用户最迫切的需求。新建数据仓库固然能从功用、功用各方面给出一个完整的处理方案,但需求投入大量的人力、物力,并且数据仓库的建设和分析数据的积累需求一段时间,无法及时满足用户对信息分析的迫切需求。因此在筹建数据仓库的前期,可以采用一些合适的表现工具,在原有OLTP系统上建立起一个逻辑的数据仓库系统。虽然由于原有OLTP系统设计上的局限性,这样的系统可能无法实现很多分析功用,但这样一个系统中数据结构固定、信息分析需求绝对稳定成熟,因此数据仓库的建模、实现过程会绝对容易、便捷;同时,这样的系统也会成为将来真负数据仓库建设的原型。信息系统与数据仓库的关系由于数据量大、数据来源多样化,在商业银行构建管理信息系统时,不可避免地会遇上如何管理这些浩如烟海的数据,以及如何从中提取有用的信息的问题;而数据仓库的最大优点在于它能把企业网络中不同信息岛上的商业数据集中到一同,存储在一个单一的集成的数据库中,并提供各种手段对数据进行统计、分析。因此可以说,在银行使用数据仓库构建管理信息系统,既有压力,又无数据基础,它们之间的联系是必然的,难以割舍的。数据仓库在商业银行的使用范围包括存款分析、贷款分析、客户市场分析、相关金融业分析决策(证券、外汇买卖)、风险预测、效益分析等。在银行信息系统构建时,由于历史情况和理想需求的不同,存在两种途径:1、建设新系统由于目前国内商业银行对银行内部运营的监管,缺乏很好的数据搜集机制,因此可以在构建管理信息系统时,分数据收集录入和数据汇总分析两部分来考虑。这样的系统中由于不需考虑大量历史数据的处理问题,同时考虑到搜集过程中可能存在多个数据来源,因此可以在系统建设的同时构建数据仓库,将搜集来的各种数据通过数据抽取整合到数据仓库中。2、完善原有系统而对于曾经存在OLTP系统,其中沉淀了大量历史数据,则可以先在原有系统上建立逻辑数据仓库,即便用数据分析的表现工具,在关系模型上构建一个虚拟的多维模型。当系统需求稳定后,再建立物理数据仓库,这样既节省投资,又缩短开发工期。实现中需求留意的问题一、模型设计中的问题模型设计(包括逻辑模型设计和物理模型设计)是系统的基础和成败的关键,在实际操作中,视实现技术的不同应分别对下列问题惹起留意。1、直接构建数据仓库直接构建数据仓库时,必须按业务分析的要求重组OLTP系统中的数据,并要按不同侧重点分别组织,使之便于使用。*主题的确定主题是一个逻辑概念,它应该能够完整、统一地刻画出分析对象所涉及的各项数据以及互相联系。划分主题的依据次要来源于两方面:对原有固定报表的分析和对业务人员的访谈。原有固定报表能较好地反映出以往任务对数据分析的需求,而且数据含义和格式绝对成熟、稳定,在模型设计中需求大量自创。但仅仅满足于替代目前的手工报表还远远不应是构建管理信息系统的目标,还应该通过业务访谈,进一步挖掘出日常任务中潜在的更广、更深的分析需求。只要这样,才能真正了解构建数据仓库模型所需的主题划分。*分析内容的细化主题的划分实际上是与分析内容的范围直接相关的,一旦主题划分清楚了,下一步就是细化分析的具体内容以及依据分析内容的性质确定它在数据仓库中的位置。通常维元素对应的是分析角度,而度量对应的是分析关怀的具体目标。一个目标究竟是作为维元素、度量还是维属性,取决于具体的业务需求,但从实际操作中可以总结出如下的概念性经验:作为维元素或维属性的通常是离散型的数据,只允许无限的取值;作为度量的是连续型数据,取值无限。如果一定要用连续型数据作为维元素,则必须对其按取值进行分段,以分段值作为实际的维元素。判断分析目标是作为维元素还是维属性时,则需求综合考虑这个目标占用的存储空间与相关查询的使用频度。需求特别强调的是,在细化分析内容的过程中,务必处理目标的歧义问题。在不同报表中以及在业务访谈中同一名称的目标,能否是在同样条件限定下,通过同样方法提取或计算得到的,它们之间的互相关系是什么,这些问题都必须从熟悉业务的分析人员那里得到精确、清晰的答案,否则将会影响到模型设计、数据提取、数据展现等多个方面。*粒度的设计数据仓库模型中所存储的数据的粒度将对信息系统的多方面产生影响。理想表中以各种维度的什么层次作为最细粒度,将决定存储的数据能否满足信息分析的功用需求,而粒度的层次划分、以及聚合表中粒度的选择将直接影响查询的呼应时间。如果同一个信息系统要在大范围、多层次上同时运转,如部门级和企业级,还应考虑不同层次的数据仓库采用不同的粒度。*模型设计中的技巧复合目标尤其是比率类目标的定义,必须留意累加时是先加减后乘除,还是反之。户数、笔数的计算,这类目标在分析或报表中经常出现,但不需求作为单独的目标物理存在于数据库中,但定义分析模型时一定应该预备。度量的时间特性,针对分析目标在时间维上的不同表现,可分为可累加目标、半可累加目标和不可累加目标。2、在原无数据基础上构建逻辑数据仓库如果直接使用OLTP系统中的数据进行数据分析处理,会遇到许多麻烦,有时甚至是不可能实现的。这并不是说关系数据库不好,而是由于其设计思路不顺应较大规模数据分析。因此在使用这种方法时,需求留意下列问题的处理:*不同的时间单位这是实现过程中最常遇到的问题,也往往是最难处理的问题。OLTP系统中存储的时间往往采用与实际业务发生相反的时间单位,如帐务数据单位为日期,财务报表单位为月或半年。而面向分析时,往往要将不同时间单位的数据统一到同一个结果中,这样就必须存在适当的转换机制才能实现。*冗余信息所谓冗余信息,就是指不同关系表中存在的同一含义的字段,而同一含义不只指这些字段的取得或计算方式一样,还指它们成立的条件一样,例如截止某一时间同一地区的同一贷种的贷款余额。在OLTP系统中,这样的字段往往是基于功用考虑而设计的,而在面向分析设计模型时,为了保证结果的独一性和精确性,就必须用且只用其中之一的数据产生分析结果。*表间连接由于OLTP系统中表的设计面向业务处理,既要保证数据的完整性、分歧性,又要考虑呼应时间,因此表与表之间既绝对独立,又互相依赖。在设计数据仓库逻辑模型时,对表间的连接必须做出相应取舍,既要保证分析数据能通过连接取得或计算出,又要避免出现环路,形成分析数据的歧义。另外,不同的连接途径还会出现不同的查询速度,影响数据分析的呼应功用。*统计表的设计如果上述问题不能在原无数据库基础上得到很好的处理,那么权益之计就是构建统计表,即简单化的数据仓库,方式类似数据仓库的理想表,定时计算统计数据放入,将时间、冗余、连接等问题摈除,进行简单分析。二、数据抽取中的问题数据抽取是一件技术含量不高,但非常烦琐的任务,必须有专人担任数据抽取的任务。在对其进行设计时,要留意的问题有:1、数据抽取的规则要作为元数据进行规范和管理,抽取过程中的源表、源字段、目的表、目的字段、转换规则以及转换条件都要作好详细记录。这样不只便于编程人员实现,而且在抽取规则或逻辑模型发生变化时也便于修正。2、如何记录业务数据库中的变动情况是数据抽取中一个重要的环节。由于数据仓库中按时间保存数据,因此不同时间点之间数据的差异就成为一个关键性要素。通常可以利用数据库管理系统提供的手段在数据库级产生数据变动日志,依据日志再判断数据的变动情况完成抽取,这样是一个从功用、可操作性以及对原业务系统的影响等多方面综合考虑都比较理想的方法。3、当数据仓库中同一表中的数据来自于原有系统中不同的表,甚至不同的库时,抽取时务必保证这些数据单位分歧