如何向Stimulsoft发送参数?

9
    public virtual ActionResult GetReportSnapshot()
    {
       var data = (ComparativeBalanceReportDS) TempData["ComparativeSession"];


        StiReport report = new StiReport();
        report.Load(Server.MapPath("~/Content/StimulReports/SampleReport.mrt"));

        report.Compile();

        report["fromDocumentNumber"] = "1";
        report["toDocumentNumber"] = "85";
        return StiMvcViewer.GetReportSnapshotResult(HttpContext, report);
   }

我有存储过程并在设计器中执行,但我没有向其中发送参数,当运行应用程序时,我会收到以下错误:

错误SqlCommand.Prepare方法要求所有可变长度参数都具有显式设置的非零大小

我该怎么办?

2个回答

10

以下代码解决了我的问题:

       public virtual ActionResult GetReportSnapshot()
        {
         var data = (ComparativeBalanceReportDS) TempData["ComparativeSession"];       
          StiReport report = new StiReport();
         report.Dictionary.DataStore.Clear();
         report.Load(Server.MapPath("~/Content/StimulReports/SampleReport.mrt"));
         report["@enterpriseId"] = data.EnterpriseId;
         report["@toDocumentNumber"] = data.NumberFilter.FromDocumentDocumentNumber;
         report["@fromDocumentNumber"] = data.NumberFilter.ToDocumentDocumentNumber;
         report["@fromDate"] = data.DateFilter.FromDocumentDate.Value;
         report["@toDate"] = data.DateFilter.ToDocumentDate.Value;
         return StiMvcViewer.GetReportSnapshotResult(HttpContext, report);

        }

4
您可以在编译报告之前使用以下代码:
report.Dictionary.DataSources["DataSourceName"].Parameters["ParameterName"].Value = ""

您还可以在参数表达式中使用其他变量。在这种情况下,您应该在呈现报告之前设置变量的值。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接