C# ASP.NET报表-设置参数

C# ASP.NET报表-设置参数,c#,asp.net,.net,reporting-services,ado.net,C#,Asp.net,.net,Reporting Services,Ado.net,我有一个名为“Graph”的存储过程,该过程应该为参数@Material获取一个值,我在ASP.NET中创建了一个报告,该报告应该使用存储过程中的数据显示一个图表 但是,当我尝试加载报告时,我得到: “数据不可用” 也就是说,参数设置不正确(默认值有效…) 背后的代码: public partial class StatisticsPage : Page { string Connectionstring = "server=(local)\\SQLEXPRESS;database=Ph

我有一个名为“Graph”的存储过程,该过程应该为参数@Material获取一个值,我在ASP.NET中创建了一个报告,该报告应该使用存储过程中的数据显示一个图表

但是,当我尝试加载报告时,我得到:

“数据不可用”

也就是说,参数设置不正确(默认值有效…)

背后的代码:

public partial class StatisticsPage : Page
{
    string Connectionstring = "server=(local)\\SQLEXPRESS;database=PhilipsMaterials;Integrated Security=SSPI";

    protected void btndisplay_Click(object sender, EventArgs e)
    {
        BindReport();
    }

    private void BindReport()
    {
        SSRSReport report = new SSRSReport();
        SqlParameter[] sqlParams = new SqlParameter[] {
         new SqlParameter("@Material","453567068441") };
        string ReportDataSource = "DataSet1";
        bool bind = report.CreateReport(Connectionstring, "graph", sqlParams, ref ReportViewer1, ReportDataSource);

        if (bind)
        {
            ReportViewer1.Visible = true;
        }
    }
}

public class SSRSReport
{     
    public bool CreateReport(String Connectionstring, string StoreProcedureName , SqlParameter[] parameters, ref Microsoft.Reporting.WebForms.ReportViewer ReportViewer, string ReportDataSource)
    {
        bool reportbind = false;
        using (SqlConnection con = new SqlConnection(Connectionstring))
        {

            SqlCommand com = new SqlCommand();
            com.Connection = con;
            com.CommandType = CommandType.StoredProcedure;
            com.CommandText = StoreProcedureName;
            com.Parameters.AddRange(parameters);
            DataSet ds = new DataSet();
            SqlDataAdapter da = new SqlDataAdapter(com);
            da.Fill(ds);
            ReportDataSource datasource = new ReportDataSource(ReportDataSource, ds.Tables[0]);
            if ( ds.Tables[0].Rows.Count > 0)
            {
                ReportViewer.LocalReport.DataSources.Clear();
                ReportViewer.LocalReport.DataSources.Add(datasource);
                ReportParameter myParam = new ReportParameter("Material", "453567068441");
                ReportViewer.LocalReport.SetParameters(myParam);
                ReportViewer.ServerReport.Refresh();
                reportbind = true;
            }                       
        }
       return reportbind;
    }
}
标记:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="StatisticsPage.aspx.cs" Inherits="StatisticsPage" %>

<%@ Register assembly="Microsoft.ReportViewer.WebForms, Version=11.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91" namespace="Microsoft.Reporting.WebForms" tagprefix="rsweb" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
    <title>Test SSRS</title>
</head>
<body>
      <form id="form1" runat="server">
        <rsweb:ReportViewer ID="ReportViewer1" runat="server" Font-Names="Verdana" Font-Size="8pt" WaitMessageFont-Names="Verdana" WaitMessageFont-Size="14pt" Height="610px" Width="1179px" ShowParameterPrompts="true">
            <LocalReport ReportPath="Report.rdlc" >
                <DataSources>
                    <rsweb:ReportDataSource DataSourceId="ObjectDataSource1" Name="DataSet1" />
                </DataSources>
            </LocalReport>
        </rsweb:ReportViewer>
        <asp:ObjectDataSource ID="ObjectDataSource1" runat="server" SelectMethod="GetData" TypeName="PhilipsMaterialsDataSetTableAdapters.GraphTableAdapter" >
            <SelectParameters>
                <asp:Parameter Name="Material"/>
          </SelectParameters>
          </asp:ObjectDataSource>
          <asp:ScriptManager ID="ScriptManager1" runat="server">
          </asp:ScriptManager>
    </form>
</body>
</html>

测试SSR

如果在没有默认参数的情况下发生错误,则问题是除非您提供值,否则
不会提供值。您可以从标记或代码中设置DefaultValue属性,该值将直接传递到后端。您还可以切换到ControlParameter、SessionParameter等,从其他地方提取值。

我不是专家,但为什么您同时使用
LocalReport
ServerReport
?你不必选择其中一个吗?我相信它是
ObjectDataSource1.SelectParameters[“Material”]。DefaultValue=“X”谢谢,代码无法以您编写的方式识别ObjectDataSource1。你能给出一个改进的代码行吗?你的代码示例有ObjectDataSource1,所以我不打算这样做。用控件的ID>替换ObjectDataSource1。此外,您也可以捕获ObjectDataSource上的Selecting事件,并以这种方式分配值。