水晶報表會自動爲每個“存儲過程中的參數”建立一個“參數字段”,所以這就成了運行時給參數賦值的問題了……
參數字段運行時自定義
[Visual Basic]
' 聲明將參數傳遞給
'查看器控件所需的變量。
Dim paramFields As New ParameterFields()
Dim paramField As New ParameterField()
Dim discreteVal As New ParameterDiscreteValue()
Dim rangeVal As New ParameterRangeValue()
' 第一個參數是具有多個值的離散參數。
' 設置參數字段的名稱,它必須
'和報表中的參數相符。
paramField.ParameterFieldName = "客戶姓名"
' 設置第一個離散值並將其傳遞給該參數
discreteVal.Value = "AIC Childrens"
paramField.CurrentValues.Add(discreteVal)
' 設置第二個離散值並將其傳遞給該參數。
' discreteVal 變量被設置爲新值,這樣,以前的設置
'就不會被覆蓋。
discreteVal = New ParameterDiscreteValue()
discreteVal.Value = "Aruba Sport"
paramField.CurrentValues.Add(discreteVal)
' 將該參數添加到參數字段集合。
paramFields.Add(paramField)
' 第二個參數爲區域值。paramField 變量
'被設置爲新值,這樣,以前的設置就不會被覆蓋。
paramField = New ParameterField()
' 設置參數字段的名稱,它必須
'和報表中的參數相符。
paramField.ParameterFieldName = "客戶 ID"
' 設置區域的開始值和結束值並將區域傳遞給該參數。
rangeVal.StartValue = 42
rangeVal.EndValue = 72
paramField.CurrentValues.Add(rangeVal)
' 將第二個參數添加到參數字段集合。
paramFields.Add(paramField)
' 將參數字段集合放入查看器控件。
crystalReportViewer1.ParameterFieldInfo = paramFields
crystalReportViewer1.ReportSource = "c:/reports/my report.rpt"
[C#]
// 聲明將參數傳遞給
//查看器控件所需的變量。
ParameterFields paramFields = new ParameterFields ();
ParameterField paramField = new ParameterField ();
ParameterDiscreteValue discreteVal = new ParameterDiscreteValue ();
ParameterRangeValue rangeVal = new ParameterRangeValue ();
// 第一個參數是具有多個值的離散參數。
// 設置參數字段的名稱,它必須
//和報表中的參數相符。
paramField.ParameterFieldName = "客戶姓名";
// 設置第一個離散值並將其傳遞給該參數。
discreteVal.Value = "AIC Childrens";
paramField.CurrentValues.Add (discreteVal);
// 設置第二個離散值並將其傳遞給該參數。
// discreteVal 變量被設置爲新值,這樣,以前的設置
//就不會被覆蓋。
discreteVal = new ParameterDiscreteValue ();
discreteVal.Value = "Aruba Sport";
paramField.CurrentValues.Add (discreteVal);
// 將該參數添加到參數字段集合。
paramFields.Add (paramField);
// 第二個參數爲區域值。paramField 變量
//被設置爲新值,這樣,以前的設置就不會被覆蓋。
paramField = new ParameterField ();
// 設置參數字段的名稱,它必須
//和報表中的參數相符。
paramField.ParameterFieldName = "客戶 ID";
// 設置範圍的開始值和結束值並將該範圍傳遞給
//該參數。
rangeVal.StartValue = 42;
rangeVal.EndValue = 72;
paramField.CurrentValues.Add (rangeVal);
// 將第二個參數添加到參數字段集合。
paramFields.Add (paramField);
// 將參數字段集合放入查看器控件。
crystalReportViewer1.ParameterFieldInfo = paramFields;
[C++]
// 聲明將參數傳遞給
//查看器控件所需的變量。
ParameterFields* paramFields = new ParameterFields ();
ParameterField* paramField = new ParameterField ();
ParameterDiscreteValue* discreteVal = new ParameterDiscreteValue ();
ParameterRangeValue* rangeVal = new ParameterRangeValue ();
// 第一個參數是具有多個值的離散參數。
// 設置參數字段的名稱,它必須
//和報表中的參數相符。
paramField->ParameterFieldName = "客戶姓名";
// 設置第一個離散值並將其傳遞給該參數。
String* val = "AIC Childrens";
discreteVal->Value = val;
paramField->CurrentValues->Add (discreteVal);
// 設置第二個離散值並將其傳遞給該參數。
// discreteVal 變量被設置爲新值,這樣,以前的設置
//就不會被覆蓋。
discreteVal = new ParameterDiscreteValue ();
val = "Aruba Sport";
discreteVal->Value = val;
paramField->CurrentValues->Add (discreteVal);
// 將該參數添加到參數字段集合。
paramFields->Add (paramField);
// 第二個參數爲區域值。paramField 變量
//被設置爲新值,這樣,以前的設置就不會被覆蓋。
paramField = new ParameterField ();
// 設置參數字段的名稱,它必須
//和報表中的參數相符。
paramField->ParameterFieldName = "客戶 ID";
// 設置範圍的開始值和結束值並將該範圍傳遞給
//該參數。
rangeVal->StartValue = __box(42);
rangeVal->EndValue = __box(72);
paramField->CurrentValues->Add (rangeVal);
// 將第二個參數添加到參數字段集合。
paramFields->Add (paramField);
// 將參數字段集合放入查看器控件。
crystalReportViewer1->ParameterFieldInfo = paramFields;
crystalReportViewer1->ExportReport();