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);
   }

我有存储过程并在设计器中执行,但我没有向它发送参数,并且在运行 App 时,我收到以下错误:

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

我该怎么办?

4

2 回答 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);

        }
于 2013-10-29T11:04:45.423 回答
4

您可以在编译报告之前使用以下代码:

report.Dictionary.DataSources["DataSourceName"].Parameters["ParameterName"].Value = ""

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

于 2013-10-29T08:27:06.837 回答