0

我所有的水晶报表都发布在我的业务对象服务器上。

它们都连接到业务视图对象。

所有这些业务视图都使用相同的动态数据连接。

这使我的报告具有此动态数据连接参数。

我可以通过中央管理控制台更改此参数。

但现在我希望能够使用 BO 的 SDK 通过代码更改它。

我有这种我认为接近实现我想要的方法,我可以保存更改。

        public static void updateParameter(IInfoObject report){

    // get all parameters
    try {
        IReport rpt = (IReport) report;
        int i = 0;
        IReportParameter params;
        for(i=0;i<rpt.getReportParameters().size();i++){
            params = (IReportParameter) rpt.getReportParameters().get(i);
            int y = 0;
            for(y=0;y<params.getCurrentValues().getValues(IReportParameter.ReportVariableValueType.STRING).size();y++){
                IParameterFieldDiscreteValue val = (IParameterFieldDiscreteValue) params.getCurrentValues().getValues(IReportParameter.ReportVariableValueType.STRING).getValue(y);
                if(val.getDescription().contains("Data Connection")){
                    val.setValue(boConstance.conn_EXAMPLE1);
                    val.setDescription(boConstance.desc_EXAMPLE1);
                    //save the new parameter ?????
                    System.out.println("report parameters modified");
                }
            }
        }

    } catch (SDKException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }


}

任何想法 ?谢谢,

4

1 回答 1

0

由于您已经在设置参数,您只需要调用 IReport 本身的 save 方法。您不会直接保存参数,因为它们是属于报表的数据。

所以在 for 循环之后完成你的例子

try {
    IReport rpt = (IReport) report;
    int i = 0;
    IReportParameter params;
    for(i=0;i<rpt.getReportParameters().size();i++){
        // do for loop here setting the parameters
    }

    rpt.save();
} catch (SDKException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
}
于 2013-12-18T19:00:45.123 回答