显示来自数据集的数据

时间:2020-06-02 11:41:44

标签: c# devexpress xtrareport

我想显示从DataSet到我的ReportViewer的数据。目前,我有4个报告,其中包含诸如NameSurnameNetworkLoginStatusOrgUnitID之类的基本数据,并且我创建了一个过滤器,该过滤器将使用StatusOrgUnitID

到目前为止,这里是代码

public void BindToData()
{
    try
    {
        DataSet ds = new DataSet();
        string connString = @"Data Source=(LocalDb)\MSSQLLocalDB;Initial Catalog=DesignSaoOsig1;Integrated Security=True";
        SqlConnection conn = new SqlConnection(connString);
        string strproc = "TestReport";
        using (SqlDataAdapter sda = new SqlDataAdapter(strproc, connString))
        {
            SqlCommand cmd = new SqlCommand();
            sda.SelectCommand.CommandType = CommandType.StoredProcedure;

            sda.SelectCommand.Parameters.Add("@Status", SqlDbType.Bit).Value = ddlStatus.SelectedValue == "1" ? true : false;
            sda.SelectCommand.Parameters.Add("@OrgJed", SqlDbType.Int).Value = ddlOrgUnit.SelectedValue;
            sda.Fill(ds);

            XtraReport report = new XtraReport();

            string nazivIzvjestaja = ds.Tables[0].Rows[0].ItemArray[0].ToString();

            if (string.IsNullOrEmpty(nazivIzvjestaja))
            {
                conn.Close();
            }

            report.DataSource = ds;
            report.DataMember = ds.Tables[0].ToString();

            string[] arrvalues = new string[ds.Tables[0].Rows.Count];

            for (int loopcounter = 0; loopcounter < ds.Tables[0].Rows.Count; loopcounter++)
            {
                //assign dataset values to array
                arrvalues[loopcounter] = ds.Tables[0].Rows[loopcounter]["PrezimeIme"].ToString();
                arrvalues[loopcounter] = ds.Tables[0].Rows[loopcounter]["NetworkLogin"].ToString();
                arrvalues[loopcounter] = ds.Tables[0].Rows[loopcounter]["Status"].ToString();
                arrvalues[loopcounter] = ds.Tables[0].Rows[loopcounter]["OrgUnitID"].ToString();
                arrvalues[loopcounter] = ds.Tables[0].Rows[loopcounter]["DT_Creat"].ToString();
                arrvalues[loopcounter] = ds.Tables[0].Rows[loopcounter]["DT_Modif"].ToString();                       
            }
        }
    }
    catch (Exception)
    {
        throw;
    }
}

到目前为止,我使用DevExpress。到目前为止,我使用for loop捕获了所有数据,但是我遇到了问题,我不知道如何将这些数据显示到Report

任何帮助都将受到欢迎。

1 个答案:

答案 0 :(得分:0)

您已经说过已将数据集与报表绑定,可以在循环结束后插入以下行来预览报表以检查结果:

        report.ShowPreview();

我注意到您正在为DevExpress使用无类型的数据集,需要对其进行序列化,因为在Dev Express的官方帖子中有详细说明: Check for the Official Website blog