mondiran简介与实例
更新时间:2024-01-20 05:59:01 阅读量: 教育文库 文档下载
- mondrian画家推荐度:
- 相关推荐
一、引言
Mondrian, 蒙得里安·皮特1872-1944荷兰画家,作品以交错的三原色为基色的垂直线条和平面为特点,他的著作包括 新造型主义(1920年),对抽象艺术的发展曾经产生很深影响。——金山词霸如是说。
不过,本文所要讨论的可不是这位艺术家。那到底mondrian是什么呢?
Mondrian是一个开源项目。一个用Java写成的OLAP(在线分析性处理)引擎。它用MDX语言实现查询,从关系数据库(RDBMS)中读取数据。然后经过Java API用多维的方式对结果进行展示。
我们都知道,在线分析处理(OLAP)要实时地分析大量数据。“online”这个词的含义就是即使相关的数据量是巨大的——可能以GB为单位——系统也要足够快的响应以显示结果。 OLAP用了多维分析的技术。尽管关系型数据库所存储的所有数据都是以行和列的形式存在的,但一个多维数据集还是可以由轴(axes)和单元(cell)组成。
在上面的例子中,时间是个维度(dimension),而它下面的层次(Hierarchies)又分为半年、季度等级别(Level)。 二、感性认识——运行一个小实例
我们暂时先不讨论Mondrian所用到的一些技术。我们可以先从一个小例子开始,不必在意每个细节,只是希望大家有个感性认识先。在实施这个例子的过程中,或许读者就能见些端倪。
首先应该到http://sourceforge.net/projects/mondrian/下载mondrian的最新版本。这是一个zip包,包括我们要用到的lib和一个例子。
当然,读者完全可以运行mondrian自带的实例,不过这个例子有些纷繁复杂,除了Mondrian本身还有其它技术在里面,不大容易讲清楚,也不太适合初学者学习。所以,笔者在这里设计一个简洁干净的最小化实例。
本文所阐述的实例环境是Windows2000+Tomcat+Oracle。并且认为读者已经针对jdk和Tomcat做了正确的开发环境的设置。 2.1准备工作
在%Tomcat%/webapp/依次建立mywebapp,mywebapp/WEB-INF,mywebapp/WEB-INF/lib,把
mondrian.war/WEB-INF/lib/mondrian.jar,javacup.jar,
xalan.jar,junit.jar等相关的jar包copy
到%TOMCAT_HOME%/webapps/mywebapp/lib/下。
2.2数据库结构
在这个tiny的系统中,数据库有3个表tb_employee(职员表),tb_time(时间表),tb_salary(薪酬表)。表结构如下:
drop table tb_employee; create table tb_employee (
employee_id number, --职员id employee_name varchar2(10) --职员姓名 );
drop table tb_time; create table tb_time (
time_id number, --时间id the_year char(4), --年 the_month char(2) --月 );
drop table tb_salary; create table tb_salary (
employee_id number, --职员id time_id number, --时间id salary number(19,4) --薪酬 );
当然,为了使系统能够运行,还需要读者向数据库表中插入一些数据。 2.3根据数据库表的结构,书写schema文件
文件路径为mywebapp/WEB-INF/mondriantest.xml 2.4利用MDX查询 mywebapp/mondriantest.jsp
1 <%@ page import=\<%
2 Connection connection = DriverManager.getConnection (\
Jdbc=jdbc:oracle:thin:@xxx.xxx.xxx.xxx:1521:dbname; JdbcUser=dbuser; JdbcPassword=dbpasswd;
Catalog=file:///c:/Tomcat4.1/webapps/mywebapp/WEB-INF/mondriantest.xml; JdbcDrivers=oracle.jdbc.driver.OracleDriver;\ 3 String queryStr=
\
{[Employee].[employeeId].Members} ON ROWS from CubeTest \
4 Query query =connection.parseQuery(queryStr); 5 Result result = connection.execute(query);
out.println(\%> 2.5运行
这时启动tomcat,在浏览器地址栏中输入
http://localhost:8080/mywebapp/ mondriantest.jsp即可。 三、深入探讨 3.1 API
mondrian为客户端应用程序提供了API接口以进行查询。 而这些API对于任何用过JDBC的人都会觉得似曾相识的。主要的不同点是查询语言的不同:Mondrian用的是MDX('Multi-Dimensional eXpressions'),而JDBC则用的是SQL。
和JDBC一样,也是要经过建立连接,形成查询语句,执行查询得到结果集等几个步骤的。 我们来看看mondriantest.jsp的代码 第1行:import mondrian.olap.*
这是引入我们所需的类,下面要用到的DriverManager、Connection、Query、Result都在这个package内。这个package一般位于mondrian.jar中。 第2行:Connection connection = DriverManager.getConnection (\
Jdbc=jdbc:oracle:thin:@xxx.xxx.xxx.xxx:1521:dbname; JdbcUser=dbuser; JdbcPassword=dbpasswd;
Catalog=file:///c:/Tomcat4.1/webapps/mywebapp/WEB-INF/mondriantest.xml; JdbcDrivers=oracle.jdbc.driver.OracleDriver;\
通过DriverManager创建一个Connection的实例,建立起数据库连接。
其中Jdbc=jdbc:oracle:thin:@xxx.xxx.xxx.xxx:1521:dbname; 是设置数据库的ip和库名。JdbcUser=dbuser; 设置数据库用户。JdbcPassword=dbpasswd; 设置用户密码。而 Catalog=file:///c:/Tomcat4.1/webapps/mywebapp/WEB-INF/mondriantest.xml; 就是设置MDX语句查询要对应的schema文件的路径 第3行:String queryStr=
\
{[Employee].[employeeId].Members} ON ROWS from CubeTest \
形成MDX的查询语句。MDX语句的形式和schema文件的设定是密切相关的,当然schema文件的形成也是由数据库结构决定的。
第4行:Query query =connection.parseQuery(queryStr);对MDX语句进行分析处理,是否符合schema文件定义、数据库结构和数据库数据。
第5行:Result result = connection.execute(query);执行查询,得到结果集。 我们发现Query类似于JDBC的Statement,而Result则酷似于ResultSet。 3.2 schema
3.2.1什么是schema
schema定义了一个多维数据库。包含了一个逻辑模型,而这个逻辑模型的目的是为了书写MDX语言的查询语句。这个逻辑模型实际上提供了这几个概念:Cubes,维度(Dimensions), 层次(Hierarchies),级别(Levels),和成员(Members)。
而schema文件就是编辑这个schema的一个xml文件。在这个文件中形成逻辑模型和数据库物理模型的对应。 3.2.2 schema的逻辑结构 3.2.2.1 Cube
一个Cube是一系列维度(Dimension)和度量(Measure)的集合区域。在Cube中,Dimension和Measure的共同地方就是共用一个事实表。 例:
标签确定了所用的事实表的表名。 3.2.2.2 Measure 一个度量,简单的说,就是要被计算的值。 例: 而维度一般有其相对应的维度表。 例: 一般Dimesion包含层次(Hierarchy),而hierarchy是由级别(Level)组成。 MDX是为了查询多维数据的,而SQL是为了查询关系数据库的。而Mondrian所涉及到的一些MDX概念、MDX语法以及系统定义的MDX函数和微软的MDX十分接近,差别微小。完全可以参考微软的帮助文档进行学习。在此就不在赘述。 四、结语 Mondrian作为基于java的OLAP引擎,而且是开源的项目,为那些基于java的项目而要脱离微软构架但又不得不对大量数据进行分析的项目又提供了一种可行的方案。希望它也能象蒙得里安·皮特对抽象艺术的发展产生影响一样起到一定的作用。 一般Dimesion包含层次(Hierarchy),而hierarchy是由级别(Level)组成。 MDX是为了查询多维数据的,而SQL是为了查询关系数据库的。而Mondrian所涉及到的一些MDX概念、MDX语法以及系统定义的MDX函数和微软的MDX十分接近,差别微小。完全可以参考微软的帮助文档进行学习。在此就不在赘述。 四、结语 Mondrian作为基于java的OLAP引擎,而且是开源的项目,为那些基于java的项目而要脱离微软构架但又不得不对大量数据进行分析的项目又提供了一种可行的方案。希望它也能象蒙得里安·皮特对抽象艺术的发展产生影响一样起到一定的作用。
正在阅读:
mondiran简介与实例01-20
教育学第三章教育与个体发展练习题10-07
北冶完小小学生综合素质评价表05-26
花海作文350字06-26
牛津高中英语模块七Unit4Welcome& Reading07-20
关于鞍钢集团与辽宁科技大学科研合作项目需求的通知 - 图文10-06
金钱小学作文06-15
09届高考文科数学第一次模拟考试201-02
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 实例
- mondiran
- 简介
- 经评审的最低投标价法评标实施细则
- 八年级数学正方形同步练习2
- 2015-2020年中国饼干产业发展现状及发展前景报告
- 廉洁自律准则学习心得体会
- 张新宝:《侵权责任法》死亡赔偿制度解读
- 工资福利讲课稿
- 关于创建文明单位工作情况的汇报
- 利润最大值模型
- 煤矿机电各个岗位责任制
- Transmission+Flexget实现RSS自动下载
- 交互式电子手册—IETM
- 动力电源题库(V2.0)
- 质谱分析综述
- 节理裂隙和边坡稳定性 - 图文
- 中等职业教育课程改革国家规划新教材英语第一册教案
- CET4 必考词汇
- 译林版七年级上册英语课文翻译Unit 1 This is me!
- 2018年江苏省南通市通州区、如东县中考数学一模试卷
- ICHQ7A
- 最新驾校科目一考试判断题