0

Asp.net 4.0 と Sap Crystal レポートを使用しています。問題は、データセットをバインドした後、reportViewer にデータを表示できないことです。

以下は私のAspxデザイナーコードです

<%@ Page Title="" Language="C#" MasterPageFile="~/Site1.Master" AutoEventWireup="true" CodeBehind="productRepot.aspx.cs" Inherits="ProductionPlanning1.productRepot" %>

<%@ Register Assembly="CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral,    PublicKeyToken=692fbea5521e1304"
Namespace="CrystalDecisions.Web" TagPrefix="CR" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="server">

<asp:Label ID="prdt_Label1" runat="server" Text="ProductID"></asp:Label>
<asp:TextBox ID="matrl_TextBox" runat="server"></asp:TextBox>

<asp:Button ID="rpt_Button1" runat="server" Text="PrintProduct" 
    onclick="rpt_Button1_Click"></asp:Button>
<CR:CrystalReportViewer ID="product_CrystalReportViewer1" runat="server" 
    AutoDataBind="true"></CR:CrystalReportViewer>

</asp:Content>

製品レポート.aspx.cs

  protected void rpt_Button1_Click(object sender, EventArgs e)
    {
        //DataSet2 DS2 = new DataSet2();
        //Fyp_1.Product pp = new Fyp_1.Product();
        //DS2.Tables.Add(pp.GetProduct(Convert.ToInt16(matrl_TextBox.Text)).Copy());
        //DS2.Tables[0].TableName = "Product";
        //CrystalReportProduct TR = new CrystalReportProduct();
        //TR.SetDataSource(DS2);
        //product_CrystalReportViewer1.ReportSource = TR;
        //product_CrystalReportViewer1.DataBind();

        GenerateReport();




        //DataSet ds = new DataSet();
        //BookTicket_Class BT = new BookTicket_Class();
           //ds.Tables.Add(BT.GetBookTicketReport(Convert.ToInt16(TicketNO_TextBox.Text)).Copy());
        //ds.Tables[0].TableName = "BookTicket";
        //TicketReport TR = new TicketReport();
        //TR.SetDataSource(ds);
        //CrystalReportViewer1.ReportSource = TR;
        //CrystalReportViewer1.DataBind();
    }

    protected void GenerateReport()
    {
        SqlConnection sqlConn = new SqlConnection(@"Data Source=PROZECK-   PC\R2MSSQLSERVER;Initial Catalog=FYP;Integrated Security=True");

        SqlCommand comd;
        comd = new SqlCommand();
        comd.Connection = sqlConn;
        comd.CommandType = CommandType.StoredProcedure;
        comd.CommandText = "spgetproductNEW";



        comd.Parameters.Add("@MaterialID", SqlDbType.Int);
      //  int VAL = Convert.ToInt32(matrl_TextBox.Text);
        if (matrl_TextBox.Text.Trim() != "")
            comd.Parameters[0].Value = Convert.ToInt32(matrl_TextBox.Text);
        else
            comd.Parameters[0].Value = DBNull.Value;




        SqlDataAdapter sqlAdapter = new SqlDataAdapter();
        sqlAdapter.SelectCommand = comd;

        DataSet2 DS2 = new DataSet2();
        sqlAdapter.Fill(DS2, "Product");

        //oRpt.SetDataSource(ds);

        //CrystalReportViewer1.Visible = true;

        //CrystalReportViewer1.ReportSource = oRpt;
        CrystalReportProduct TR = new CrystalReportProduct();
        TR.SetDataSource(DS2);
        product_CrystalReportViewer1.ReportSource = TR;
       // product_CrystalReportViewer1.DataBind();




    }
}

以下は、問題のスクリーンショットです。

ここに画像の説明を入力

しかし、Crystal Report Designerでデータを確認すると、データが表示されます ここに画像の説明を入力

データをバインドする最初のコードはこれで、貼り付けた上記のコードに変更しました

        DataSet2 DS2 = new DataSet2();
        Fyp_1.Product pp = new Fyp_1.Product();
        DS2.Tables.Add(pp.GetProduct(Convert.ToInt16(matrl_TextBox.Text)).Copy());
        DS2.Tables[0].TableName = "Product";
        CrystalReportProduct TR = new CrystalReportProduct();
        TR.SetDataSource(DS2);
        product_CrystalReportViewer1.ReportSource = TR;
        product_CrystalReportViewer1.DataBind();
4

3 に答える 3

0

最後の電話を逃しただけだと思います。product_CrystalReportViewer1.Refresh();

于 2012-12-04T07:51:32.997 に答える