如何向水晶報表數據源中的存儲過程傳參數……

水晶報表會自動爲每個“存儲過程中的參數”建立一個“參數字段”,所以這就成了運行時給參數賦值的問題了……

參數字段運行時自定義

[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();

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章