これはVisualStudio2008では正しく機能していましたが、VisualStudio2010とCrystalReportsfor Visual Studio 2010に切り替えたため、渡されたパラメーターは無視されます。
それらはレポートに表示されますが、選択式に関しては無視されます。これが、レポートを作成してパラメーターを渡すための私のコードです。
private void Prepare()
{
var reportDocument = new ReportDocument();
string reportPath = string.Format(
"{0}\\{1}",
Globals.FormPath,
this.FormTemplate.Filename);
reportDocument.Load(reportPath);
ParameterDiscreteValue parameter;
foreach (var control in this.FormTemplateFieldControls)
{
switch (control.FormTemplateField.DataType)
{
case FormFieldDataType.Date:
this.AddParameterForDateTime(
reportDocument,
control.FormTemplateField.Name,
(DateTime)control.EditValue);
break;
case FormFieldDataType.DateTime:
this.AddParameterForDateTime(
reportDocument,
control.FormTemplateField.Name,
(DateTime)control.EditValue);
break;
case FormFieldDataType.Time:
this.AddParameterForDateTime(
reportDocument,
control.FormTemplateField.Name,
(DateTime)control.EditValue);
break;
case FormFieldDataType.Guid:
this.AddParameterForGuid(
reportDocument,
control.FormTemplateField.Name,
(Guid)control.EditValue);
break;
default:
this.AddParameterForString(
reportDocument,
control.FormTemplateField.Name,
control.EditValue.ToString());
break;
}
}
this.SetConnectionInfo(reportDocument);
var frm = new FormViewer();
frm.Report = reportDocument;
frm.ShowDialog();
frm.Dispose();
this.Close();
}
デザイナーからのレポートを実行すると、問題なく機能します。レポートにパラメーターを表示しているときに、パラメーターが渡されていることがわかります。

ストアドプロシージャから実行される私のレポートの場合、パラメータは問題なく通過するように見えます。これは、すべてのテーブルで構成されるものだけです。
それが価値があるものについては、ここに私の選択式があります:
{employee.HireDate} >= {?StartDate} And {employee.HireDate} <= {?EndDate}