Retrieves rows from the database for a DataWindow control or DataStore. If arguments are included, the argument values are used for the retrieval arguments in the SQL SELECT statement for the DataWindow object or child DataWindow.
RetrieveEx A separate method name is provided as an alternative syntax for the Web DataWindow server component, which cannot use overloaded methods. The RetrieveEx method for the server component takes a string of values for an argument. The DataWindow Web ActiveX control can also use a RetrieveEx method, but it uses an array for an argument instead of a string of values.
DataWindow type |
Method applies to |
---|---|
PowerBuilder |
DataWindow control, DataWindowChild object, DataStore object |
Web |
Client control, PSWebDataWindowClass, server component |
Web ActiveX |
DataWindow control, DataWindowChild object |
long dwcontrol.Retrieve ( { any argument, any argument . . . } )
number dwcontrol.Retrieve ( )
Web DataWindow PSWebDataWindowClass
number dwcontrol.Retrieve ( { variant argument, variant argument . . . } )
Web DataWindow server component
int dwcontrol.Retrieve ( )
int dwcontrol.RetrieveEx ( string argument )
number dwcontrol.Retrieve ( { variant argument, variant argument . . . } )
number dwcontrol.RetrieveEx ( variant argument [ ] )
Argument |
Description |
---|---|
dwcontrol |
A reference to a DataWindow control, DataStore, or child DataWindow. |
argument (optional with Retrieve, required with RetrieveEx) |
One or more values that you want to use as retrieval arguments in the SQL SELECT statement defined in dwcontrol. This must be a single string containing one or more values for the Web DataWindow server component (see Usage note). It must be a single array of values for the Web ActiveX control. |
Returns the number of rows displayed (that is, rows in the primary buffer) if it succeeds and -1 if it fails. If there is no DataWindow object assigned to the DataWindow control or DataStore, this method returns -1.
This method always returns -1 if the data source is external. Use a method such as ImportFile to populate the DataWindow.
After rows are retrieved, the DataWindow object’s filter is applied. Therefore, any retrieved rows that do not meet the filter criteria are immediately moved to the filter buffer and are not included in the return count.
Before you can retrieve rows for a DataWindow control or DataStore, you must specify a transaction object with SetTransObject or SetTrans. If you use SetTransObject, you must also use a SQL CONNECT statement to establish a database connection.
Normally, when you call Retrieve, any rows that are already in the DataWindow control or DataStore are discarded and replaced with the retrieved rows. You can return the code 2 in the RetrieveStart event to prevent this. In this case, Retrieve adds any retrieved rows to the ones that already exist in the buffers.
If arguments are expected but not specified, the user is prompted for the retrieval arguments.
A retrieval argument can be null if the SELECT statement is designed to handle null values. For example, if a two-part WHERE clause is separated by OR, then either part can be null while the other matches values in the database.
Calling Retrieve causes data to be retrieved on the server. Then the page is reloaded.
Using retrieval arguments Page parameters hold the retrieval argument values that were used for the current page. To return these values to the server for the next retrieval, specify the page parameter names and expressions that are the values of the retrieval arguments in the HTMLGen.SelfLinkArgs property.
In case of retrieve error All methods that reload the page perform an AcceptText before sending data back to the server. If Retrieve fails (returns -1), this means that pending data changes were not accepted and nothing was sent back to the server. In this situation the ItemError event occurs.
If you need to include retrieval arguments, call RetrieveEx instead of Retrieve.
The argument for the RetrieveEx method is a string that contains the values of all the retrieval arguments expected by the DataWindow object associated with the server component.
The string has the format:
value1 \n value2 \n value3... \n value16
The values of the retrieval arguments must be separated by newline characters (\n) and individual values cannot contain newline characters as part of the value. The Web DataWindow supports up to 16 retrieval arguments.
You can specify an array for the value of a retrieval argument by separating the array values with a tab character (\t). For example, if the DataWindow expects an array for the second retrieval argument, the syntax would be:
value1 \n value2a\t value2b \t value2c \n value3...
When the retrieval arguments are passed to the page as page parameters, call SetSelfLink to provide the information to recreate the page parameters each time the page is reloaded. After you retrieve data, call Generate to render the data on a Web page in a Web DataWindow client control.
Call GetLastError and GetLastErrorString to get information about database errors that cause SetAction, Update, Retrieve, and RetrieveEx to return -1.
The argument for the Retrieve method uses the same format as the argument for the RetrieveEx method of the Web DataWindow server component. If Retrieve or Update return -1, the OnDBError event is triggered.
Retrieve may trigger these events:
DBError
RetrieveEnd
RetrieveRow
RetrieveStart
None of these events is triggered if the data source is external, because Retrieve always fails. You must use one of the import methods to populate the DataWindow.
This statement causes dw_emp1 to retrieve rows from the database.
dw_emp1.Retrieve()
This example illustrates how to set up a connection and then retrieve rows in the DataWindow control. A typical scenario is to establish the connection in the application’s Open event and to retrieve rows in the Open event for the window that contains the DataWindow control.
The following is a script for the application open event. SQLCA is the default transaction object. The ProfileString function is getting information about the database connection from an initialization file:
// Set up Transaction object from the INI file
SQLCA.DBMS = ProfileString("myapp.ini", &
"Database", "DBMS", " ")
SQLCA.DbParm = ProfileString("myapp.ini", &
"Database", "DbParm", " ")
// Connect to database
CONNECT USING SQLCA;
// Test whether the connect succeeded
IF SQLCA.SQLCode <> 0 THEN
MessageBox("Connect Failed", &
"Cannot connect to database." &
+ SQLCA.SQLErrText)
RETURN
END IF
Open(w_main)
To continue the example, the open event for w_main sets the transaction object for the DataWindow control dw_main to SQLCA and retrieves rows from the database.
If no rows were retrieved or if there is an error (that is, the return value is negative), the script displays a message to the user:
long ll_rows
dw_main.SetTransObject(SQLCA)
ll_rows = dw_main.Retrieve()
IF ll_rows < 1 THEN MessageBox( &
"Database Error", &
"No rows retrieved.")
This example illustrates the use of retrieval arguments. Assume that :Salary and :Region are declared as arguments in the DataWindow painter and dw_emp has this SQL SELECT statement:
SELECT Name, emp.sal, sales.rgn From Employee, Sales
WHERE emp.sal > :Salary and sales.rgn = :Region
Then this statement causes dw_emp1 to retrieve employees from the database who have a salary greater than $50,000 and are in the northwest region:
dw_1.Retrieve(50000, "NW")
This example also illustrates retrieval arguments. Assume dw_EmpHist contains this SQL SELECT statement and emps is defined as a number array:
SELECT EmpNbr, Sal, Rgn From Employee
WHERE EmpNbr IN (:emps)
These statements cause dw_EmpHist to retrieve Employees from the database whose employee numbers are values in the array emps:
Double emps[3]
emps[1] = 100
emps[2] = 200
emps[3] = 300
dw_EmpHist.Retrieve(emps)
The following example illustrates how to use Retrieve twice to get data meeting different criteria. Assume the SELECT statement for the DataWindow object requires one argument, the department number. Then these statements retrieve all rows in the database in which department number is 100 or 200.
The script for the RetrieveStart event in the DataWindow control sets the return code to 2 so that the rows and buffers of the DataWindow control are not cleared before each retrieval:
RETURN 2
The script for the Clicked event for a Retrieve CommandButton retrieves the data with two function calls. The Reset method clears any previously retrieved rows, normally done by Retrieve.
Here, Retrieve is prevented from doing it by the return code in the RetrieveStart event:
dw_1.Reset( )
dw_1.Retrieve(100)
dw_1.Retrieve(200)
For the Web DataWindow server component, if the user entered a product ID in a form to get detailed information on the product, the product ID is passed to the product report template as a page parameter. The page parameter should always exist because it comes from the calling page, but the code provides a default value anyway:
String prod_id;
prod_id=(String) request.getParameter("ProdID");
if (prod_id == null){
prod_id = "1";
}
dwGen.SetSelfLink( "ProdID=" + "'\"" + prod_id + "\"'");
dwGen.RetrieveEx(prod_id);