对mondrian的重新认识

刚接触OLAP不久,最开始接触的必然脱离不了Mondrian,大家似乎都很清楚Mondrian是一个OLAP SERVER,除了它还有很多其它的。在探究Mondrian和大量的olap server及client时,碰到很多的问题,在解决和思考这些问题之后,终于明白mondrian的真谛,或许认识的过程不应该像我这样,走了一些弯路。

官方示例是一个不错的东西,能快速给出最终效果。但对于初学者,还是有个隐患,特别是没有集中方向细致地分析的时候。下面列一下探究mondrian的过程,方向不是很清晰,以示启发:
(1)搭起环境,跑起示例。
(2)在query/xmla.jsp下尝试连ssas,成功。相当然地思索为什么能连ssas,从mondrian的源码库看到了xmla的处理模块,还是国人写的。思维导向成此模块在处理这些soap消息,下结论mondrian能连其它遵循XML/A标准的olap server,并且此想法持续好几天。
(3)也清楚olap4j支持xml/a标准,不仅认为mondrian能连,还能支持schema,session等olap4j不具备的东西。
(4)自定义http request发送到基于mondrian的web app,在定义http body时,与发送到其它olap server时不同,比如icCube, palo等。很讷闷,一开始感觉是mondrian的xmla处理模块的差异。这直是大错,也没仔细研究xmla模块对soap消息的包装,其实mondrian的xmla模块对soap消息没有包装。包装是jpivot的wrapper等类干的事。
(5)标签库jp:xmlaQuery很诡异,虽然能应付ssas这种独立source的url,但在包装需要指定datasource属性的palo和icCube等时,显然还需要在示例上增进。

你可能感兴趣的:(mondrian)