首页 > 解决方案 > 如何修复设置报表参数时出现的这个rdlc本地报表处理错误

问题描述

我想在不使用报告查看器的情况下保存 rdlc 报告,并且在没有报告参数的情况下我成功了,就像当我尝试将报告参数添加到报告时我得到的和“报告处理错误”一样。

我尝试保存不带参数的报告并且它有效,但是一旦我添加参数,它就会生成此错误。

try
{
                using (IDbConnection db = new SQLiteConnection(ConfigurationManager.ConnectionStrings["cs"].ConnectionString))
                {
                    if (db.State == ConnectionState.Closed)
                    {
                        db.Open();
                    }
                    string getOrderItems = "Select * from OrderItems where OrderId = 20";
                    List<OrderItem> orderItems = db.Query<OrderItem>(getOrderItems, commandType: CommandType.Text).ToList();
                    OrderItemBindingSource.DataSource = orderItems;
                }
                LocalReport orderReceipt = new LocalReport();
                orderReceipt.ReportPath = @"D:\ADiTM\Products\ADiTmPoS\ADiTmPoS\Reports\OrderReceipt.rdlc";
                ReportDataSource rds = new ReportDataSource();
                rds.Name = "orderItem";
                rds.Value = this.OrderItemBindingSource;
                orderReceipt.DataSources.Add(rds);
                ReportParameter[] parameters = new ReportParameter[]
                {
                    new ReportParameter("CustomerName",orderDetail.CustomerName),
                    new ReportParameter("CustomerContactNumber",orderDetail.CustomerContactNumber),
                    new ReportParameter("CustomerAddress",orderDetail.CustomerAddress),
                    new ReportParameter("OrderId",orderDetail.Id.ToString()),
                    new ReportParameter("Date",orderDetail.Date.ToString("MM/DD/yyyy")),
                    new ReportParameter("Status",orderDetail.Status),
                    new ReportParameter("StaffName",orderDetail.StaffName),
                    new ReportParameter("StaffMobileNumber",orderDetail.StaffMobileNumber),
                    new ReportParameter("UserName",orderDetail.UserName)

                };
                orderReceipt.SetParameters(parameters);

                Byte[] mybytes = orderReceipt.Render("PDF");
                using (var fbd = new FolderBrowserDialog())
                {
                    DialogResult result = fbd.ShowDialog();
                    if (result == DialogResult.OK && !string.IsNullOrWhiteSpace(fbd.SelectedPath))
                    {
                        using (FileStream fs = File.Create(fbd.SelectedPath + "OrderReceipt22.pdf"))
                        {
                            fs.Write(mybytes, 0, mybytes.Length);
                        }
                        MetroFramework.MetroMessageBox.Show(this, "Order Receipt Saved", "Success!", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    }

                }
            }
            catch (Exception ex)
            {
                MetroFramework.MetroMessageBox.Show(this, ex.Message, "Message", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }

我使用断点,它给出了错误

orderReceipt.SetParameters(parameters);

标签: c#sqliterdlc

解决方案


这是一条令人讨厌的错误消息,但只要您的 rdlc 运行时版本大于 2015,您就应该能够利用它的鲜为人知的改进:查看InnerException,并将处理程序附加到ReportError 事件

orderReceipt.ReportError += new EventHandler(orderReceipt_ReportError);

private void orderReceipt_ReportError(object sender, ReportErrorEventArgs e)
{
    MetroFramework.MetroMessageBox.Show(this, e.Exception.ToString(), "Failed!", MessageBoxButtons.OK, MessageBoxIcon.Information);
    e.Handled = true;
}

将详细说明哪个参数是罪魁祸首以及它有什么问题。常见原因:拼写错误、类型不匹配、可空性不匹配。


推荐阅读