|
|
|
|
|
- Example for managing the positions in a data file
- Reinitializing positions
- Miscellaneous
- Repositioning by OLE DB and Native MySQL, DB2 and Informix Connectors
<Source>.SavePosition (Function) In french: <Source>.SauvePosition
Not available with this kind of connection
Stores the current context of a data file: current record, filter, pointers. This allows you to temporarily suspend the current process in order for the data file to be used somewhere else (to perform checks for example). The saved context can be restored by <Source>.RestorePosition. Then, the main process can continue. <Source>.SavePosition is used to save: - the number of the record used,
- the different pointers in the index (the position in the index is saved for each key),
- the current filter. You will have to use the hRPFilter constant in <Source>.RestorePosition to restore the stored filter.
This function can be used with the data files, HFSQL views or queries.
// Find a record Customer.ReadSeekFirst(Name, Name) WHILE Customer.Found() = True // Saves the current context nPos = Customer.SavePosition(Name) // Check a customer with another name Customer.ReadSeek(Name, Name2) IF Customer.Found() = True THEN Counter = Counter + 1 // Restores the context HRestorePosition(nPos) Customer.ReadNext(Name) END Syntax
<Result> = <Source>.SavePosition([<Item>] [, <Options>])
<Result>: Integer - Number of the position that was saved,
- -1 if an error occurred.
<Source>: Type corresponding to the specified source Name of the data file, view or query used. If this name is not specified, <Source>.SavePosition will use the last data file used by the last HFSQL function (function starting with "H"). <Item>: Optional character string Name of the item used. If this parameter is not specified, <Source>.SavePosition saves the positions of all items being looped through.
<Options>: Optional integer constant Used to configure the backup:
| | | hSaveItems | Saves the values of items in memory when using <Source>.SavePosition. These values will be restored next time <Source>.RestorePosition is called. | |
Remarks Example for managing the positions in a data file - form used to display a record and to loop through the data file according to a key. Another window is called to display the data as a table. Positions allow you to easily go back to desired record in the iteration.
- viewing a data file in a Table control. When selected, the record is displayed as a form, with the possibility of looping through forms. The position management allows you to display the Table control again while being properly positioned on the data file.
Reinitializing positions Caution: all the functions that open or close a data file reinitialize the context numbers ( HCreation, <Source>.Close, etc.). Miscellaneous - The number of calls to <Source>.SavePosition is not limited.
- You have the ability to nest <Source>.SavePosition and <Source>.RestorePosition for the same data file.
- If the record pointed during the call to <Source>.SavePosition is deleted, <Source>.RestorePosition cannot be called anymore.
Business / UI classification: Business Logic
This page is also available for…
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|