在 StackOverFlow 中阅读此线程后:SSRS Subreport VS2010 data retrieve failed for the subreport后,我仍然收到“子报告的数据检索失败”。主报表和子报表在 BIDS 2008 中运行良好,因此我的 .cs 或 .aspx 页面一定有问题。我正在使用的代码如下。谁能告诉我我做错了什么?谢谢!
页面:
<asp:DropDownList ID="DropDownListVisit" runat="server" DataTextField="VisitList"
DataValueField="VisitID" AutoPostBack="True" AppendDataBoundItems="true"
onselectedindexchanged="DropDownListVisit_SelectedIndexChanged"
DataSourceID="EntityDataSourceVisitDropDown">
<asp:ListItem Text="--- Select Ship & Visit ---" Value="" Selected="True"></asp:ListItem>
</asp:DropDownList>
<asp:EntityDataSource ID="EntityDataSourceVisitDropDown" runat="server"
ConnectionString="name=Admiral_NSSAEntities"
DefaultContainerName="Admiral_NSSAEntities" EnableFlattening="False"
EntitySetName="vw_VisitList"
Select="it.[VisitID], it.[VisitList], it.[ShipName], it.[StartDate]"
OrderBy="it.[ShipName] asc, it.[StartDate] desc">
</asp:EntityDataSource>
<rsweb:ReportViewer ID="ReportViewerSummeryReportOutBrief" runat="server" Font-Names="Verdana"
Font-Size="8pt" InteractiveDeviceInfos="(Collection)"
WaitMessageFont-Names="Verdana" WaitMessageFont-Size="14pt" Width="1139px"
Height="894px" PageCountMode="Actual" PromptAreaCollapsed="True"
style="margin-right: 0px">
<LocalReport ReportPath="Secured\Reports\SummeryReportOutBrief.rdlc">
<DataSources>
<rsweb:ReportDataSource DataSourceId="EntityDataSourceVisitInfo"
Name="VisitInfo" />
<rsweb:ReportDataSource DataSourceId="EntityDataSourceWorkOrders"
Name="WorkOrders" />
<rsweb:ReportDataSource DataSourceId="EntityDataSourcePartsDataByWorkOrder"
Name="PartsDataByWorkOrder" />
</DataSources>
</LocalReport>
</rsweb:ReportViewer>
<asp:EntityDataSource ID="EntityDataSourcePartsDataByWorkOrder" runat="server"
ConnectionString="name=Admiral_NSSAEntities"
DefaultContainerName="Admiral_NSSAEntities" EnableFlattening="False"
EntitySetName="vw_PartsDataByWorkOrder" >
</asp:EntityDataSource>
<asp:EntityDataSource ID="EntityDataSourceWorkOrders" runat="server"
AutoGenerateOrderByClause="True" AutoGenerateWhereClause="True"
ConnectionString="name=Admiral_NSSAEntities"
DefaultContainerName="Admiral_NSSAEntities" EnableFlattening="False"
EntitySetName="vw_WorkOrders" Where="">
<WhereParameters>
<asp:ControlParameter ControlID="DropDownListVisit" DbType="Guid"
Name="VisitID" PropertyName="SelectedValue" />
</WhereParameters>
</asp:EntityDataSource>
<asp:EntityDataSource ID="EntityDataSourceVisitInfo" runat="server"
AutoGenerateOrderByClause="True" AutoGenerateWhereClause="True"
ConnectionString="name=Admiral_NSSAEntities"
DefaultContainerName="Admiral_NSSAEntities" EnableFlattening="False"
EntitySetName="vw_VisitInfo" Where="">
<WhereParameters>
<asp:ControlParameter ControlID="DropDownListVisit" DbType="Guid"
Name="VisitID" PropertyName="SelectedValue" />
</WhereParameters>
</asp:EntityDataSource>
</asp:Content>
后面的代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Microsoft.Reporting.WebForms;
using System.Configuration;
public partial class Secured_Reports_SummeryReportOutBriefAll : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (DropDownListVisit.SelectedValue == "")
{
this.ReportViewerSummeryReportOutBrief.Visible = false;
ReportViewerSummeryReportOutBrief.LocalReport.Refresh();
ReportViewerSummeryReportOutBrief.LocalReport.SubreportProcessing += new SubreportProcessingEventHandler(SubreportProcessingEventHandler);
}
}
public void SubreportProcessingEventHandler(object sender, SubreportProcessingEventArgs e)
{
e.DataSources.Add(new ReportDataSource("PartsDataByWorkOrder", this.EntityDataSourcePartsDataByWorkOrder));
}
protected void DropDownListVisit_SelectedIndexChanged(object sender, EventArgs e)
{
//In App_Code _TemplateFiles
Reports.ShowReport(this.DropDownListVisit, this.ReportViewerSummeryReportOutBrief);
}
}