0

我在使用 Java API 运行 MaxL“导出数据库”命令时遇到了问题。我试过使用这样的代码:(参考 Essbase Java API 示例 com.essbase.test.ExecuteMaxl.java)

IEssMaxlSession test = olapSvr.openMaxlSession("test"); test.execute("export database sample.basic using report_file 'top.rep' to data_file 'c:/topExp.txt'"); 它失败,但有以下异常:

无法执行 maxl 语句。Essbase 错误 (1290101):此 MaxL 语句需要客户端支持。尚不支持此功能。

我正在运行 Essbase 11.1.2.1 和相同版本的 Java API。

4

3 回答 3

1

您没有告诉 Essbase 在哪里可以找到报告文件。如果“top.rep”在服务器上,那么您必须在 Maxl 语句中明确引用它。因此,它将是:“...使用服务器report_file”。否则,如果文件托管在客户端上,您必须像为输出数据文件所做的那样指定路径(例如“c:/top.rep”)

Rgds,阿莱蒙

于 2014-11-28T00:14:06.597 回答
0

根据我的经验,通过 Java API 运行 MaxL 命令不起作用,并给出指示的错误(也就是说,它可能依赖于 C API 中的一些本机代码,但正如它所说,它不受支持)。为什么不在 Java API 中使用报表运行命令?

于 2014-11-28T23:48:06.180 回答
0

要导出数据为什么不使用 java api 方法 exportData

    private static void exportData(IEssCube cube) throws EssException {
    System.out.println("Exporting data BSO");

    // As the path is relative, file will be exported to "ARBORPATH/app/Demo/Basic" on Essbase server.
    cube.exportData("Demo/Basic/exportedData.txt",IEssCube.EEssDataLevel.ALL, true);


    // As the path is absolute, file will be exported to "C:/temp/exportedData.txt" on Essbase server.
   //cube.exportData("C:/temp/exportedData.txt",IEssCube.EEssDataLevel.ALL, true);

    System.out.println("Exporting data Complete.");

}
于 2016-12-03T20:39:09.373 回答