ASP.net: ReportViewer не отображается (параметры из динамически создаваемых текстовых полей)

У меня есть существующий код, который отображает отчет RDL сервера отчетов в программе просмотра отчетов. Я запрашиваю у пользователя входные данные, и они затем передаются в качестве параметров в процедуру хранения на Sql Server.

Отчет генерируется должным образом как подтверждение концепции с жестко запрограммированным количеством текстовых полей, но, очевидно, не все отчеты будут иметь одинаковое количество параметров. Вот мой рабочий код и скриншот:

Рабочий отчет

ASP.NET

<%@ Page Language="C#" Trace="true" AutoEventWireup="true" CodeBehind="Reports.aspx.cs" Inherits="FormsAuthAd.Reports" %>

<%@ Register Assembly="Microsoft.ReportViewer.WebForms, Version=11.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91" Namespace="Microsoft.Reporting.WebForms" TagPrefix="rsweb" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml" class="reports-body">
<head runat="server">
    <title>Reports</title>
    <link href="../css/Style.css" rel="stylesheet" />
</head>
<body>
    <form id="form1" runat="server">
    <asp:ScriptManager ID="ScriptManager1" runat="server"></asp:ScriptManager>
    <div class="params-container container">
        <asp:TextBox ID="txtStart" runat="server" placeholder="From Date" class="input-fields"></asp:TextBox>
        <asp:TextBox ID="txtEnd" runat="server" placeholder="To Date" class="input-fields"></asp:TextBox>
        <asp:TextBox ID="txtBrand" runat="server" placeholder="Brand" class="input-fields"></asp:TextBox>
        <asp:TextBox ID="txtSeason" runat="server" placeholder="Season" class="input-fields"></asp:TextBox>
        <asp:TextBox ID="txtComp" runat="server" placeholder="Company" class="input-fields"></asp:TextBox>
        <asp:TextBox ID="txtLoc" runat="server" placeholder="Location" class="input-fields"></asp:TextBox>
        <asp:TextBox ID="txtLine" runat="server" placeholder="Line" class="input-fields"></asp:TextBox>
        <asp:Button ID="btnShow" runat="server" OnClick="Button1_Click" Text="Generate"  class="input-fields"/>
    </div>
    <div class="rpt-container container">
        <rsweb:ReportViewer ID="rptVwr" runat="server" CssClass="rpt-viewer"></rsweb:ReportViewer>
    </div>
    </form>
</body>
</html>

Код позади

private void showReport()
{
    rptVwr.Reset();
        DataTable dt = GetData(txtStart.Text, txtEnd.Text, txtBrand.Text, txtSeason.Text, txtComp.Text, txtLoc.Text);
        rptVwr.Visible = true;
        ReportDataSource rds = new ReportDataSource("DataSet2", dt);
        rptVwr.LocalReport.DataSources.Add(rds);
        rptVwr.LocalReport.ReportPath = "../ReportServer/StockExport.rdl";

        ReportParameter[] rptParams = new ReportParameter[]
        {
        new ReportParameter("StartDate",txtStart.Text),
                new ReportParameter("EndDate",txtEnd.Text),
                new ReportParameter("Brand",txtBrand.Text),
                new ReportParameter("Season",txtSeason.Text),
                new ReportParameter("Company",txtComp.Text),
                new ReportParameter("Store",txtLoc.Text),
        };
        rptVwr.LocalReport.SetParameters(rptParams);
        rptVwr.LocalReport.Refresh();
}

private DataTable GetData(string fromDate, string toDate, string brandCode, string seasonCode, string compCode, string locCode)
{
    DataTable dt = new DataTable();
        string connStr = System.Configuration.ConfigurationManager.ConnectionStrings ["ReportServerConnStr"].ConnectionString;
        using (SqlConnection cn = new SqlConnection(connStr))
        {
            SqlCommand cmd = new SqlCommand("sp_valueEntryStock", cn);
                cmd.CommandType = CommandType.StoredProcedure;
                cmd.Parameters.Add("@StartDate", SqlDbType.NVarChar).Value = fromDate;
                cmd.Parameters.Add("@EndDate", SqlDbType.NVarChar).Value = toDate;
                cmd.Parameters.Add("@Season", SqlDbType.NVarChar).Value = seasonCode;
                cmd.Parameters.Add("@Brand", SqlDbType.NVarChar).Value = brandCode;
                cmd.Parameters.Add("@Company", SqlDbType.NVarChar).Value = compCode;
                cmd.Parameters.Add("@Store", SqlDbType.NVarChar).Value = locCode;
                cmd.CommandTimeout = 1000;
                SqlDataAdapter adp = new SqlDataAdapter(cmd);
                adp.Fill(dt);
    }
        return dt;

}

protected void Button1_Click(object sender, EventArgs e)
{
    showReport();
}

Очевидно, я не хотел жестко запрограммировать количество текстовых полей, поэтому я настроил свой код для динамического добавления текстовых полей при загрузке страницы на основе таблицы в Sql Server. Вот мой существующий код и снимок экрана:

Страница после отправки параметров

Код позади

protected void Page_Load(object sender, EventArgs e)
{
    using (SqlConnection con = new SqlConnection(connStr))
        {
            using (SqlCommand cmd = new SqlCommand("SELECT [FieldNum],[FieldName],[AspId],[SqlParameter] FROM [MIS_FieldsMaster]", con))
                {
                    cmd.CommandType = CommandType.Text;
                        SqlDataAdapter adp = new SqlDataAdapter(cmd);
                        adp.Fill(dtable);
                        int i = 0;
                        foreach (DataRow dr in dtable.Rows)
                        {
                            TextBox tb = new TextBox();
                            tb.ID = dr["AspId"].ToString().Trim();
                            stringArray[i] = dr["SqlParameter"].ToString().Trim();
                            tb.Text = stringArray[i];
                            ph1.Controls.Add(tb);
                            i++;
                        }
                }
    }

}

private void showReport()
{
    rptVwr.Reset();
        DataTable dt = GetData();
        rptVwr.Visible = true;
        ReportDataSource rds = new ReportDataSource("DataSet2", dt);
    rptVwr.LocalReport.DataSources.Add(rds);
    rptVwr.LocalReport.ReportPath = "../ReportServer/StockExport.rdl";
        rptVwr.LocalReport.Refresh();
}

private DataTable GetData()
{
    DataTable dt = new DataTable();
        int i = 0;

        string connStr = System.Configuration.ConfigurationManager.ConnectionStrings["ReportServerConnStr"].ConnectionString;
        using (SqlConnection cn = new SqlConnection(connStr))
        {
        SqlCommand cmd = new SqlCommand("sp_valueEntryStock", cn);
                cmd.CommandType = CommandType.StoredProcedure;
                foreach (TextBox textBox in ph1.Controls.OfType<TextBox>())
                {
                    cmd.Connection = cn;
            cmd.Parameters.AddWithValue("@" + stringArray[i], textBox.Text);
                    i++;
                }
                cmd.CommandTimeout = 1000;
                SqlDataAdapter adp = new SqlDataAdapter(cmd);
                adp.Fill(dt);
    }
            return dt;
}

protected void Button1_Click(object sender, EventArgs e)
{
    showReport();
}

Так что он даже не показывает мне сообщения об ошибке, поэтому я не знаю, где искать. Я отладил новый код и считаю, что он извлекает данные в хранимой процедуре, потому что локальная переменная показывает строки, полученные в datatable dt. Единственное, отчет не отображается в reportViewer. Он даже не показывает панели инструментов отчета.

Строка, полученная из datatable dt

Я был бы очень признателен за любую помощь. Благодарю.

1 ответ

Я выяснил причину, по которой отчет не отображается в программе просмотра отчетов.

Похоже, мне все еще нужно добавить параметры и установить их для средства просмотра отчетов, как в моем первом рабочем коде:

ReportParameter[] rptParams = new ReportParameter[]
{
new ReportParameter("StartDate",txtStart.Text),
        new ReportParameter("EndDate",txtEnd.Text),
        new ReportParameter("Brand",txtBrand.Text),
        new ReportParameter("Season",txtSeason.Text),
        new ReportParameter("Company",txtComp.Text),
        new ReportParameter("Store",txtLoc.Text),
};
rptVwr.LocalReport.SetParameters(rptParams);

Очевидно =, он все еще должен быть динамическим, поэтому вот код, который я использовал:

List<ReportParameter> paramList = new List<ReportParameter>();
int i = 0;

foreach (TextBox textBox in ph1.Controls.OfType<TextBox>())
{
    paramList.Add(new ReportParameter(stringArray[i], textBox.Text));
    i++;
}
rptVwr.LocalReport.SetParameters(paramList);

Теперь я могу генерировать динамические текстовые поля и в то же время передавать значения в этих текстовых полях в свою хранимую процедуру на сервере sql и, наконец, генерировать и отображать отчет, основанный на тех же текстовых полях.

Я бы посчитал, что это решено, но у меня просто вопрос в голове:

Почему мой код не работает, когда он точно такой же (по крайней мере, логически, если не синтаксически), как код в примере с YouTube, который я взял: двухсторонняя передача параметра в хранимой процедуре и отображение вывода в средстве просмотра отчетов с помощью C#

Другие вопросы по тегам