我使用的是最新的Saiku 3.8.3独立版本,我在使用数据库PostgreSQL 9.1时遇到了一些问题,不同的模式就是PUBLIC。
我创建了数据源并且连接正确,这里是我正在使用的数据源而没有个人详细信息:
type=OLAP
name=chegadaturistas
driver=mondrian.olap4j.MondrianOlap4jDriver
location=jdbc:mondrian:Jdbc=jdbc:postgresql://DBNAME:PORT/DB;Catalog=mondrian:///datasources/chegada_turistas.xml;JdbcDrivers=org.postgresql.Driver;
username=postgres
password=PASSWORD
security.enabled=false
我还创建了具有legancy选项的Mondrian Schema,因为我使用了Schema Workbench。这是我创建的Schema:
<Schema name="DEPES" description="DEPES">
<Cube name="CHEGADAS" visible="true" cache="true" enabled="true">
<Table name="chegada" schema="fato" alias="chegada">
</Table>
<Dimension type="StandardDimension" visible="true" foreignKey="id_tempo" highCardinality="false" name="Ano">
<Hierarchy name="ANO" visible="true" hasAll="true" allMemberName="Todos os Anos" primaryKey="id_tempo">
<Table name="tempo" schema="dimensao" alias="Tempo">
</Table>
<Level name="ANO" visible="true" column="nu_ano" nameColumn="nu_ano" ordinalColumn="nu_ano" type="Integer" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
</Hierarchy>
</Dimension>
<Dimension type="StandardDimension" visible="true" foreignKey="id_origem" highCardinality="false" name="Origem">
<Hierarchy name="Origem" visible="true" hasAll="true" allMemberName="Todas as Origens" primaryKey="id_origem">
<Table name="origem" schema="dimensao">
</Table>
<Level name="Continente" visible="true" column="no_continente" nameColumn="no_continente" ordinalColumn="no_continente" type="String" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
<Level name="Pais" visible="true" column="no_pais" nameColumn="no_pais" ordinalColumn="no_pais" type="String" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
</Hierarchy>
</Dimension>
<Dimension type="StandardDimension" visible="true" foreignKey="id_via" highCardinality="false" name="Via">
<Hierarchy name="Via" visible="true" hasAll="true" allMemberName="Todas as Vias" primaryKey="id_via">
<Table name="via" schema="dimensao">
</Table>
<Level name="Nome" visible="true" column="id_via" nameColumn="no_via" ordinalColumn="no_via" type="Integer" uniqueMembers="true" levelType="Regular" hideMemberIf="Never">
</Level>
</Hierarchy>
</Dimension>
<Dimension type="StandardDimension" visible="true" foreignKey="id_destino" highCardinality="false" name="Destino">
<Hierarchy name="Destino" visible="true" hasAll="true" allMemberName="Todos os Destinos" primaryKey="id_destino">
<Table name="destino" schema="dimensao">
</Table>
<Level name="Regiao" visible="true" column="no_regiao" nameColumn="no_regiao" ordinalColumn="no_regiao" type="String" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
<Level name="UF" visible="true" column="no_uf" nameColumn="no_uf" ordinalColumn="no_uf" type="String" uniqueMembers="true" levelType="Regular" hideMemberIf="Never">
</Level>
</Hierarchy>
</Dimension>
<Dimension type="StandardDimension" visible="true" foreignKey="id_tempo" highCardinality="false" name="Mes">
<Hierarchy name="Mes" visible="true" hasAll="true" allMemberName="Todos os Meses" primaryKey="id_tempo">
<Table name="tempo" schema="dimensao">
</Table>
<Level name="Nome do Mes" visible="true" column="nu_mes" nameColumn="no_mes" ordinalColumn="nu_mes" type="String" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
<Level name="Número do Mes" visible="true" column="nu_mes" nameColumn="nu_mes" ordinalColumn="nu_mes" type="Integer" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
</Hierarchy>
</Dimension>
<Dimension type="StandardDimension" visible="true" foreignKey="id_tempo" highCardinality="false" name="Semestre">
<Hierarchy name="Semestre" visible="true" hasAll="true" allMemberName="Todos os Semestres" primaryKey="id_tempo">
<Table name="tempo" schema="dimensao">
</Table>
<Level name="Número do Semestre" visible="true" column="nu_semestre" nameColumn="nu_semestre" ordinalColumn="nu_semestre" type="Integer" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
<Level name="Descrição do Semestre" visible="true" column="nu_semestre" nameColumn="no_semestre" ordinalColumn="no_semestre" type="String" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
</Level>
</Hierarchy>
</Dimension>
<Measure name="qt_chegada" column="qt_chegada" datatype="Integer" aggregator="sum" caption="Chegadas" description="Quantidade de Turistas" visible="true">
</Measure>
</Cube>
<Schema>
问题是,当我运行Saiku时,我无法看到架构,并且在日志中出现此错误:
2016-04-08 08:17:31,976 WARN [mondrian.rolap.RolapSchema] Model is in legacy format
2016-04-08 08:17:36,725 ERROR [org.saiku.web.core.SecurityAwareConnectionManager] Error connecting: chegadaturistas
mondrian.olap.MondrianException: Mondrian Error:Internal error: Reading row count from table [null, null, tempo]; sql=[select count(*) from "tempo"]
所以我注意到COUNT中mondrian使用的select只是表而不是应该在PostgreSQL上使用的schema.table。为了确保我在PostgreSQL公共模式中创建了一个VIEW,并且它没有在“tempo”表中给我这个错误,而是给了我另一个。有没有办法迫使Mondrian在PosgreSQL的选择上使用SCHEMA.TABLE?
答案 0 :(得分:1)
问题解决了!看起来当你把Mondrian 3 XML放在Mondrian 4上时(Saiku 3.X使用Mondrian 4)它会升级XML,但它只是“忘记”在更新后放入数据库SCHEMA标签。这是我做的解决方案,感谢Tom Barber(他在Google上的Saiku小组回答了这个问题。
所以只需找到log4j.xml,取消注释(不要重复,它已在文件中注释):
<appender name="MONDRIAN" class="org.apache.log4j.RollingFileAppender">
<param name="File" value="${catalina.base}/logs/mondrian.log"/>
<param name="Append" value="false"/>
<param name="MaxFileSize" value="500KB"/>
<param name="MaxBackupIndex" value="1"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
</layout>
</appender>
<category name="mondrian">
<priority value="DEBUG"/>
<appender-ref ref="MONDRIAN"/>
</category>
停止SAIKU并再次启动它。稍等一下,打开saiku.log(它位于“saiku_directory”\ tomcat \ logs \ saiku.log上,搜索一下这样的行:
<Schema name="YOUR_SCHEMA_NAME" missingLink="ignore" metamodelVersion="4.300">
<PhysicalSchema>
........
复制整个架构并粘贴到新的file.xml上,在所有TABLE标签上插入标签schema =“SCHEMA_NAME”,如下所示:
OLD:
<Table name="chegada" alias="chegada">
NEW:
<Table name="chegada" schema="fato" alias="chegada">
再次启动SAIKU,上传此架构,重新启动saiku。
问题解决了! :d