C# 将值从第一个表单传递到多个crystal报表
我有问题,每次我重新加载其他crystal报告时,参数都在寻找值。我只使用一个crystalreportviewerC# 将值从第一个表单传递到多个crystal报表,c#,crystal-reports,C#,Crystal Reports,我有问题,每次我重新加载其他crystal报告时,参数都在寻找值。我只使用一个crystalreportviewer ReportDocument rd = new ReportDocument(); public string user; string repCust = @"C:\Users\Jeff Enad\Desktop\TEST1\Cebu Hallmark Hotel Management System\Cebu Hallmark Hotel Manage
ReportDocument rd = new ReportDocument();
public string user;
string repCust = @"C:\Users\Jeff Enad\Desktop\TEST1\Cebu Hallmark Hotel Management System\Cebu Hallmark Hotel Management System\cryCustomer.rpt";
string repRept = @"C:\Users\Jeff Enad\Desktop\TEST1\Cebu Hallmark Hotel Management System\Cebu Hallmark Hotel Management System\cryReport.rpt";
string repRooms = @"C:\Users\Jeff Enad\Desktop\TEST1\Cebu Hallmark Hotel Management System\Cebu Hallmark Hotel Management System\cryRooms.rpt";
public frmReport(string User)
{
InitializeComponent();
loadReport();
this.user = User;
}
第一批crystal报告:
public void loadReport()
{
rd.Load(repRept);
SqlConnection con = new SqlConnection(@"Data Source=.\SQLEXPRESS;Initial Catalog=dbCebuHallmark;Integrated Security=True");
SqlDataAdapter da = new SqlDataAdapter("GetAllReport", con);
da.SelectCommand.CommandType = CommandType.StoredProcedure;
DataSet ds = new System.Data.DataSet();
da.Fill(ds, "REPORT");
rd.SetDataSource(ds);
crystalReportViewer1.ReportSource = rd;
crystalReportViewer1.Refresh();
}
通过参数:
private void frmReport_Load(object sender, EventArgs e)
{
cmbLoadReport.SelectedIndex = 0;
rd.SetParameterValue("UserPrinted", this.user);
rd.SetParameterValue("DatePrinted", DateTime.Today.ToString("MM-dd-yyyy hh:mm tt"));
}
我用于重新加载多个crystal报告的代码:
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
string cryBy = "";
string loadBy = "";
string tableBy = "";
string paraBy = "";
if (cmbLoadReport.SelectedIndex == 0)
{
cryBy = repRept;
loadBy = "GetAllReport";
tableBy = "REPORT";
}
else if (cmbLoadReport.SelectedIndex == 1)
{
cryBy = repRooms;
loadBy = "GetRoom";
tableBy = "ROOM";
paraBy = "Vacant";
}
else if (cmbLoadReport.SelectedIndex == 2)
{
cryBy = repRooms;
loadBy = "GetRoom";
tableBy = "ROOM";
paraBy = "Occupied";
}
else if (cmbLoadReport.SelectedIndex == 3)
{
cryBy = repCust;
loadBy = "GetCustomer";
tableBy = "CUSTOMER";
}
rd.Load(cryBy);
SqlConnection con = new SqlConnection(@"Data Source=.\SQLEXPRESS;Initial Catalog=dbCebuHallmark;Integrated Security=True");
SqlDataAdapter da = new SqlDataAdapter(loadBy, con);
da.SelectCommand.CommandType = CommandType.StoredProcedure;
if (cmbLoadReport.SelectedIndex != 0 && cmbLoadReport.SelectedIndex != 3)
{
da.SelectCommand.Parameters.Add("@availability", System.Data.SqlDbType.VarChar, 50).Value = paraBy;
}
DataSet ds = new System.Data.DataSet();
da.Fill(ds, tableBy);
rd.SetDataSource(ds);
crystalReportViewer1.ReportSource = rd;
crystalReportViewer1.Refresh();
}
我听不懂这个问题,你能再解释一下吗?您已经为itI分配了值。我将一个值传递给多个crystal report,每次我重新加载另一个crystal report时,它都会请求参数值。您是否应该在每次调用时都将参数传递给report?这是经常发生的事情。你的要求有什么不同?