用oracle分析函数实现行列转换

用oracle分析函数实现行列转换

ID:8928159

大小:80.06 KB

页数:7页

时间:2018-04-12

用oracle分析函数实现行列转换_第1页
用oracle分析函数实现行列转换_第2页
用oracle分析函数实现行列转换_第3页
用oracle分析函数实现行列转换_第4页
用oracle分析函数实现行列转换_第5页
资源描述:

《用oracle分析函数实现行列转换》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、用ORACLE分析函数实现行列转换黄莉玉素甫·艾白都拉(新疆师范大学数理信息学院,新疆830054)摘要 对数据库中的数据用SQL实现行列转换,不但需要编写复杂的程序代码,还需要编写存储过程。若引入ORACLE中的分析函数则会使该过程简便很多。首先找出表中所有关键字的属性个数的最大值,设为n,其次为每个关键字新添加n列,并用分析函数查询关键字的属性所处列的位置,然后将每个关键字的多行属性转换成多列属性,最后把生成的多个新列拼成一个串形成一列,从而实现行列转换。关键字 Oracle数据库;分析函数;行列转换1 引言分析函数的设计目的是为了解决诸

2、如“累计计算”等问题。虽然大部分的问题都可以用PL/SQL解决,但是性能并不理想,首先查询本身并不容易编写,其次有些很难在SQL中直接做的查询但实际上是很普通的操作,比如实现数据表中行列传换。这样的问题在SQL中做查询就很困难。在分析函数出现以前,我们必须使用自联查询或者子查询甚至复杂的存储过程实现的语句,现在只要一条简单的SQL语句就可以实现了,而且在执行效率方面也有相当大的提高。本文将以一个实例来描述如何采用分析函数实现数据中的行列互换。2 原理2.1 分析函数的格式及语法分析函数是在一个记录行分组的基础上计算它们的总值。行的分组被称窗口

3、,并通过分析语句定义。对于每记录行,定义了一个“滑动”窗口。该窗口确定“当前行”计算的范围。窗口的大小可由各行的实际编号或由时间等逻辑间隔确定。分析函数以如下形式开头:Analytic-Function(,...)OVER()(1)Analytic-Function:分析函数的名称,Oracle10gR2带的内置分析函数有多个,包括:AVG、CORR、COVAR_POP、COVAR_S

4、AMP、COUNT、LAG、LAST、LEAD、MAX、MIN、RANK、SUM等;对于用户自定义的分析函数,分析函数名称需要满足标识符规则。(2)Arguments:参数,分析函数通常有0到3个参数,参数可以是任何数字类型或是可以隐式转换为数字类型的数据类型。对于用户自定义的参数,可以根据实际情况使用。(3)OVER:是分析函数就必须使用的关键字,对于既可作为聚集函数又可作为分析函数的函数,Oracle无法识别,必须用over来标识此函数为分析函数。(4)Query-Partition-Clause:查询分组子句,根据划分表达式设置的规则,

5、PARTITIONBY将一个结果逻辑分成N个分组划分表达式。分析函数独立应用于各个分组,并在应用时重置。(5)Order-By-Clause:(按…排序分组),是排序子句,根据一个或多个排序表达式对分组进行排序。(6)Windowing-Clause窗口生成语句:窗口生成语句用以定义滑动或固定数据窗口,分析函数在分组内进行分析。该语句能够对分组中任意定义的滑动或固定窗口进行计算。2.2 实例原理介绍本实例是将具有相同关键字的多条记录中的某一不同列合并成一列,例如在一个临时表中包含有用户的编号、电话号码、产品名称、所在营业区以及相关业务名称5个

6、字段,而每个用户的业务可能有多项,这样创建数据表将会造成冗余,现在要想办法将表中编号、电话号码、产品名称、所在营业区四个字段相同的用户的相关业务属性合并成一列解决冗余问题,使用SQL语句会比较困难,甚至需要一定的存储过程。使用Orcale中的分析函数来实现这样的行列转换就比较简单方便了。3 实例1)创建临时表DropTabletemp;CreateTabletemp(numvarchar2(15Char),namevarchar2(20Char),sexvarchar2(2Char),classesvarchar2(30Char),cours

7、e_namevarchar2(50Char));2)构造数据insertintotemp(num,name,sex,classes,course_name)values('206211','王艺','男','06-1班','保险学');insertintotemp(num,name,sex,classes,course_name)values('206212','肖薇','女','06-2','保险学');insertintotemp(num,name,sex,classes,course_name)values('206212','肖薇',

8、'女','06-2','财务管理');insertintotemp(num,name,sex,classes,course_name)values('206212'

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。