利用物化视图和Ecel数据透视表

利用物化视图和Excel数据透视表实现一卡通数据查询师职门诊一卡通试用以来,院领导常需要有关体系外师职干部门诊就诊情况的有关信息,进而需要体系内的军人就诊情况,甚至包括同比和环比相关就诊信息情况。这些需求,需要的数据是固定的,但展现的形式是不定的。因此,不适合在下发的程序中固定,其实更确切地讲,这是一个初步的BI要求。下文中,主要介绍如何结合ORACLE的物化视图和Excel的数据透视表(图)功能,实现上述要求并提供扩展空间。一.物化视图ORACLE的物化视图(MaterialedView)可用于预先计算保存连接或聚集等耗时较多的操作的结果。这和军卫一号中医务统计中的统计中间表功能类似,但更灵活。关于军人门诊就诊和门诊费用的统计,我们也可以将有关统计生成为物化视图,方面查询使用。下面脚本以ORACLE10G为例,其它版本可自行调整。为不影响HIS系统,我选择单建用户和表空间以方便今后的删除。以DBA用户执行:---建立存储表空间CREATETABLESPACETSP_INSURANCE_SUMDATAFILE'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\DATAFILE\O1_MF_TSP_INSU_75H7Z9VT_.DBF'SIZE100MAUTOEXTENDONNEXT5MMAXSIZEUNLIMITEDNOLOGGINGDEFAULTCOMPRESSONLINEPERMANENTEXTENTMANAGEMENTLOCALUNIFORMSIZE10MBLOCKSIZE8KSEGMENTSPACEMANAGEMENTMANUALFLASHBACKOFF;---建立用户CREATEUSER"CARDSUM"IDENTIFIEDBY"CARDSUM"DEFAULTTABLESPACETSP_INSURANCE_SUMTEMPORARYTABLESPACETEMP---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---GRANTCREATEMATERIALIZEDVIEWTOCARDSUM;GRANTCREATEPROCEDURETOCARDSUMWITHADMINOPTION;GRANTSELECTANYTABLETOCARDSUM;GRANTUNLIMITEDTABLESPACETOCARDSUM;GRANT"CONNECT"TO"CARDSUM";ALTERUSER"CARDSUM"DEFAULTROLE"CONNECT";ALTERUSERCARDSUMAUNLIMITEDONTSP_INSURANCE_SUM;以cardsum用户执行:---判断是否是体系内外,通过判断帐号的体系医院和本院代码/*Formattedon2011/08/2720:27(FormatterPlusv4.8.6)*/CREATEORREPLACEFUNCTIONgetserviceclass(a_visit_dateDATE,a_insurance_noVARCHAR2)RETURNVARCHAR2ISv_serviceclassVARCHAR2(30);v_hospital_codehospital_config.unit_code%TYPE;--±¾Ôº´úÂëv_inservicelistVARCHAR2(1);v_service_classVARCHAR2(29);/******************************************************************************NAME:GetServiceClassPURPOSE:获取指定帐号的身份信息参数:a_visit_date就诊时间a_insurance_no帐号返回值:第一字符标明是体系内(0)还是体系外(1),第二个字符标明身份REVISIONS:VerDateAuthorDescription-------------------------------------------------------------------------本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---1.02011-8-141.Createdthisfunction.NOTES:AutomaticallyavailableAutoReplaceKeywords:ObjectName:GetServiceClassSysdate:2011-8-14DateandTime:2011-8-14,10:52:27,and2011-8-1410:52:27Username:TableName:(setinthe"NewPL/SQLObject"dialog)******************************************************************************/BEGINSELECTunit_codeINTOv_hospital_codeFROMhospital_config;SELECTDECODE(designated_hospital,v_hospital_code,0,1),identity_classINTOv_inservicelist,v_service_classFROMinsurance_accountsWHEREinsurance_no=a_insurance_no;IFv_inservicelist=1THEN--外体系BEGINSELECTservice_classINTOv_service_classFROMoutp_card_bill_itemsWHEREvisit_date=a_visit_dateANDinsurance_no=a_insurance_noANDROWNUM=1;EXCEPTIONWHENNO_DATA_FOUNDTHENNULL;END;ENDIF;v_serviceclass:=v_inservicelist||v_service_class;RETURNv_serviceclass;EXCEPTION---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---WHENNO_DATA_FOUNDTHENRETURN'1其它';WHENOTHERSTHEN--Considerloggingtheerrorandthenre-raiseRETURN'1其它';ENDgetserviceclass;/---创建门诊就诊的物化视图---本文...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供参考,付费前请自行鉴别。
3、如文档内容存在侵犯商业秘密、侵犯著作权等,请点击“举报”。

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

客服邮箱:

biganzikefu@outlook.com

所有的文档都被视为“模板”,用于写作参考,下载前须认真查看,确认无误后再购买;

文档大部份都是可以预览的,笔杆子文库无法对文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;

文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为依据;

如果您还有什么不清楚的或需要我们协助,可以联系客服邮箱:

biganzikefu@outlook.com

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

笔杆子文秘
机构认证
内容提供者

为您提供优质文档,供您参考!

确认删除?