支持MDX XMLA的OLAP客户端---FlexOlapView开发手册
概述
FlexOlapView构件是一个用于多维分析的FLASH控件,可通过XMLA标准协议连接至OLAP服务器,如:微软的SQL Server分析服务器(MS SSAS2005/2008)和Pentaho分析服务(Mondrian)等,它可以用数据透视表和多种图表展示多维分析数据,实现实时业务分析。本文讲述开发者怎样将FlexOlapView控件应用到自已的项目中。
架构
样例
可以传入不同的参数,定义FlexOlapView的展现形式,可以只展示图形,多维表格,或是复杂的分析工具界面,举例如下:
参数说明
开发人员将控件放入网页,并正确设置以下参数:
参数 |
说明 |
备注 |
show_mode |
显示模式 |
1:report; 2:view; 3:edit; 4:columnchart 5:piechart 6:lineChart 7:barChart |
show_toolbar |
是否显示工具栏 |
1:显示 |
mdx |
MDX查询语句 |
可以为空 |
dataSource |
数据源 |
"Provider=Mondrian;DataSource=Pentaho"; |
cubeName |
Cube名 |
"SteelWheelsSales"; |
serviceURL |
OLAP 服务URL |
"http://localhost:8080/pentaho/Xmla?userid=joe&password=password"; |
useNumberColor |
是否用不同颜色标识数据 |
0:否 |
highColor |
高过上限的数据颜色 |
16711680; //FF0000 |
lowColor |
低于下限的数据颜色 |
204; //0x00FF00 |
highThreshold |
数值上限 |
10000; |
lowThreshold |
数值下限 |
1000; |
举例如下:
例子 |
<script type="text/javascript"> |
参考文档:
《flash使用FlashVars接收html参数》
一、在HTML网页中使用js获取参数。
我们知道HTML页面是在客户端执行的,这样要获取参数必须使用客户端脚本(如JavaScript),在这点上不同于服务器端脚本获取参数方式。
下面的这段js代码获取HTML网页形如"test.html?foo=mytest&program=flash" "?"后所有参数。
<script language=javascript>
<!--
var hrefstr,pos,parastr;
hrefstr = window.location.href;
pos = hrefstr.indexOf("?");
parastr = hrefstr.substring(pos+1);
if (pos>0){
document.write("所有参数:"+parastr);
} else {
document.write("无参数");
}
//-->
</script>
下面的这段js代码则可以更加细化获取HTML网页某一参数
<script language=javascript>
<!--
function getparastr(strname) {
var hrefstr,pos,parastr,para,tempstr;
hrefstr = window.location.href;
pos = hrefstr.indexOf("?")
parastr = hrefstr.substring(pos+1);
para = parastr.split("&");
tempstr="";
for(i=0;i<para.length;i++)
{
tempstr = para[i];
pos = tempstr.indexOf("=");
if(tempstr.substring(0,pos) == strname) {
return tempstr.substring(pos+1);
}
}
return null;
}
// 获取program参数
var programstr = getparastr("program");
document.write(programstr);
//-->
</script>
二、在HTML网页中向swf传递参数。
方法一:在网页中使用js,SetVariable设置flashobject中的变量,代码如:
// "HtmlToSwf"为网页中的flashobject ID
HtmlToSwf.SetVariable("_root.info_str","Happy Newyear");
方法二:路径参数,如test.swf?foo=happy2005
方法三:使用FlashVars,以下主要介绍FlashVars的用法。使用FlashVars后嵌入HTML的flashobject代码如下:
<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,0,0" width="550" height="400" id="FlashVars" align="middle">
<param name="allowScriptAccess" value="sameDomain" />
<param name="movie" value="FlashVars.swf" />
<param name="FlashVars" value="foo=happy2005&program=flash&language=简体中文-中国" />
< param name="quality" value="high" />
<param name="bgcolor" value="#ffffff" />
<embed src="FlashVars.swf" quality="high" bgcolor="#ffffff" width="550" height="400" name="FlashVars" align="middle" allowScriptAccess="sameDomain" FlashVars="foo=happy2005&program=flash&language=简体中文-中国" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" />
通过上面的代码,在SWF(FlashVars.swf)中就可以直接获取foo、program、language变量数据。FlashVars.fla获取FlashVars参数的代码如下:
// 创建三个文本字段
_root.createTextField("foo_txt",1,0,0,16,16);
_root.createTextField("program_txt",2,0,32,16,16);
_root.createTextField("language_txt",3,0,64,16,16);
foo_txt.autoSize = true;
foo_txt.border = true;
program_txt.autoSize = true;
program_txt.border = true;
language_txt.autoSize = true;
language_txt.border = true;
// 获取FlashVars变量
foo_txt.text = "HTML中的foo参数:"+foo;
program_txt.text = "HTML中的program参数:"+program;
language_txt.text = "HTML中的language参数:"+language;
三、两者的有效结合。
在HTML网页中使用js获取参数,然后将获取的参数作为FlashVars写入flashobject传递给swf。代码如下:
<script language=javascript>
<!--
function writeflashobject(parastr) {
document.write("<object classid=\"clsid:d27cdb6e-ae6d-11cf-96b8-444553540000\" codebase=\"http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,0,0\" width=\"550\" height=\"400\" id=\"FlashVars\" align=\"middle\"\>\n");
document.write("<param name=\"allowScriptAccess\" value=\"sameDomain\" /\>\n");
document.write("<param name=\"movie\" value=\"FlashVars.swf\" /\>\n");
document.write("<param name=\"FlashVars\" value=\""+ parastr +"\" /\>\n");
document.write("<param name=\"quality\" value=\"high\" /\>\n");
document.write("<param name=\"bgcolor\" value=\"#ffffff\" /\>\n");
document.write("<embed src=\"FlashVars.swf\" quality=\"high\" bgcolor=\"#ffffff\" width=\"550\" height=\"400\" name=\"FlashVars\" align=\"middle\" allowScriptAccess=\"sameDomain\" FlashVars=\""+ parastr +"\" type=\"application/x-shockwave-flash\" pluginspage=\"http://www.macromedia.com/go/getflashplayer\" /\>");
document.write("</object\>");
}
function getparastr() {
var hrefstr,pos,parastr,para,tempstr1;
hrefstr = window.location.href;
pos = hrefstr.indexOf("?")
parastr = hrefstr.substring(pos+1);
return parastr;
}
var parastr = getparastr();
writeflashobject(parastr);
//-->
</script>
相关推荐
Java OLAP4J-XMLA-1.1.0.jar 库正是利用XMLA协议与OLAP服务器进行通信的桥梁,使得Java应用能够透明地访问支持XMLA的OLAP服务。 **JAVA SSAS**: SQL Server Analysis Services (SSAS) 是微软提供的一个企业级OLAP...
此外,olap4j还支持多种数据源类型,包括JDBC(Java Database Connectivity)和XMLA(XML for Analysis),这使得它能够与多种类型的OLAP服务器兼容,如 mondrian、MicroStrategy、Oracle OLAP等。同时,由于olap4j...
这些工具的“XMLA+MDX”接口降低了开发OLAP客户端的复杂性,提高了跨平台的兼容性。对于开发者来说,理解XMLA的工作原理和如何使用Discover和Execute方法进行数据访问是关键。 在实践中,XMLA通信通常通过HTTP进行...
本实例由两部分组成:一个是Mondrian提供的XMLA服务端,一个是Olap4j的XMLA客户端,利用XMLA服务访问元数据和执行MDX查询。 详见http://blog.csdn.net/chch87
在提供的压缩包`jdbc4olap-1.1.4`中,我们可以期待找到以下内容: 1. `jdbc4olap` 的JAR文件:这是驱动程序的核心库,包含了实现SQL-MDX转换和XMLA通信的所有必要类和方法。 2. 文档:可能包含API参考、用户指南、...
OLAP.js 用于浏览器和Node.jsJavaScript在线分析处理服务器和库 (c)2015年Andrey Gershun( ) 工作正在进行中! Express OLAP服务器 var olap = require ( 'olap' ) ; olap . xmla ( ) ; olap olap . ...
mondrian ROLAP MDX 经典资料打包。 MDX的基本语法及概念.ppt ROLAP的概念.ppt 如何将Mondrian用于web项目.ppt MDX的基本语法及概念.ppt doc_cn jpivot
2. **MDX支持**:MDX是用于多维数据集的查询语言,XMLA Processor提供了处理MDX查询的工具。这包括解析MDX语句,生成相应的XML/A请求,并解析响应以获取结果集。 3. **多维数据结构**:XMLA Processor内建了一个...
它实现了xmla和jolap规范,而且自定义了一种使用mdx语言的客户端接口。Mondrian是olap服务器,而不是数据仓库服务器,因此Mondrian的元数据主要包括olap建模的元数据,不包括从外部数据源到数据库转换的元数据。也...
Mondrian则是一款用Java编写的开源OLAP服务器,它支持MDX语言及XML for Analysis (XMLA) 和 JOLAP 规范。本文将详细介绍MDX的基础概念、Mondrian的安装与配置以及如何利用Mondrian执行基本的MDX查询。 #### 二、...
第三部分面向Integration Services开发人员,详细介绍如何使用SSIS开发ETL软件包,利用ETL包加载OLAP多维数据集和数据挖掘结构;第四部分详细介绍了SSRS的架构,以及Excel、Visio或Office SharePoint Server 2007...
第三部分面向Integration Services开发人员,详细介绍如何使用SSIS开发ETL软件包,利用ETL包加载OLAP多维数据集和数据挖掘结构;第四部分详细介绍了SSRS的架构,以及Excel、Visio或Office SharePoint Server 2007...
第三部分面向Integration Services开发人员,详细介绍如何使用SSIS开发ETL软件包,利用ETL包加载OLAP多维数据集和数据挖掘结构;第四部分详细介绍了SSRS的架构,以及Excel、Visio或Office SharePoint Server 2007...
第三部分面向Integration Services开发人员,详细介绍如何使用SSIS开发ETL软件包,利用ETL包加载OLAP多维数据集和数据挖掘结构;第四部分详细介绍了SSRS的架构,以及Excel、Visio或Office SharePoint Server 2007...
1. **客户端**: 客户端可以通过MDX查询、XMLA请求或JOLAP API等方式获取元数据。 2. **MDX与元数据**: MDX查询可以直接返回元数据信息,例如维度、层次结构等。 3. **XMLForAnalysis与元数据**: 通过XMLA接口,...
XMLA(XML for Analysis)是一种用于与OLAP服务器通信的协议,它可以用来执行MDX查询和管理多维数据。关于XMLA的表现性能,如果数据量较小,使用XSLT进行转换可能不会有显著的性能问题。但随着数据量的增加,XSLT...
- **OLAP与多维数据分析**:讨论了OLAP如何支持多维数据分析,并通过实例展示了其优势。 **第2章:多维空间** - **多维模型**:定义了多维模型的概念,包括维度、度量值、层次结构等。 - **多维分析的优势**:分析...
5. **XMLA连接**:XMLA是一种标准协议,允许客户端应用程序与OLAP服务器进行通信。mondrian源码中的XMLA支持使得JavaScript或其他Web应用程序能够与mondrian交互,进行数据分析。 6. **Schema文件**:mondrian的...