在网上查了一下,发现了Mondrian。Mondrian是基于JAVA的数据仓库引擎,可以集成到web项目中,这一点最吸引我。另外与他搭配的表现层的方案也有不少选择,Jpivot是元老,pentaho,openi看起来是后起之秀。不管怎样,还是先研究一下modrian吧
网上的中文资源比较少,在csdn上找了一下,只发现了两篇比较有用的
http://dev.csdn.net/develop/article/31/31791.shtm Mondrian——有影响的“艺术家” 选择自 kswaking 的 Blog
http://dev.csdn.net/develop/article/68/68661.shtm 穷人的通用OLAP方案III--JPivot表现层 选择自 calvinxiu 的 Blog
照着做了一下,发现了一些问题,也有了一些心得。
一.环境准备
1.1 首先介绍一下环境
操作系统:Linux
服务器:Tomcat 5.5
数据库:MySQL 5.0.21
1.2 下载程序。Mondrian在http://mondrian.sourceforge.net 可以下载,最早他是用MS Analyze Service的教程中FoodMart数据库作为demo的,那个是access的数据库。还好现在他有了Platform-Independent的版本,我就下载了那个mondrian-2.1.1-derby.zip 解压缩之后在lib目录里面有一个mondrian-embedded.war,把这个直接放到tomcat的webapps目录里面就能够看到mondrian的demo了。不过后面的测试,我把这个war解开之后放到webapps里面去,并且目录把名字改短了点mondrian。启动tomcat,在浏览器输入http://localhost/mondiran 看到了demo。需要说明一下的是,mondrian的发布包含了Jpivot,用它来做展示层,所以不用再去单独下载Jpivot了。
1.3 数据库建表,在MySQL数据库里面建立table,借用了kswaking的数据库结构
在这个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, &