|  | 
|  | constructor (hash< auto > h) | 
|  | Creates the hash list iterator object. 
 | 
|  | 
|  | constructor () | 
|  | Creates an empty hash list iterator object. 
 | 
|  | 
|  | copy () | 
|  | Creates a copy of the HashListReverseIterator object, iterating the same object as the original and in the same position. 
 | 
|  | 
| bool | first () | 
|  | returns True if on the first element being iterated in the list (ie the last element in the list) 
 | 
|  | 
| bool | last () | 
|  | returns True if on the last element being iterated in the list (ie the first element in the list) 
 | 
|  | 
| auto | memberGate (string key) | 
|  | This method allows the iterator to be dereferenced directly as a hash for the current row being iterated, as memberGate methods are called implicitly when an unknown member is accessed from outside the class. 
 | 
|  | 
| bool | next () | 
|  | Moves the current position to the next element in the result list; returns False if there are no more elements; if the iterator is not pointing at a valid element before this call, the iterator will be positioned on the first element in the list if the list is not empty. 
 | 
|  | 
| bool | prev () | 
|  | Moves the current position to the previous element in the result list; returns False if there are no more elements; if the iterator is not pointing at a valid element before this call, the iterator will be positioned on the last element in the list if the list is not empty. 
 | 
|  | 
|  | constructor (hash< auto > h) | 
|  | Creates the hash list iterator object. 
 | 
|  | 
|  | constructor () | 
|  | Creates an empty hash list iterator object. 
 | 
|  | 
|  | copy () | 
|  | Creates a copy of the HashListIterator object, iterating the same object as the original and in the same position. 
 | 
|  | 
| bool | empty () | 
|  | returns True if the result list is empty; False if not 
 | 
|  | 
| bool | first () | 
|  | returns True if on the first element of the list 
 | 
|  | 
| auto | getKeyValue (string key) | 
|  | Returns the current value for the column given as an argument. 
 | 
|  | 
| hash< auto > | getRow () | 
|  | returns the current row value as a hash or throws an INVALID-ITERATORexception if the iterator is invalid
 | 
|  | 
| hash< auto > | getValue () | 
|  | returns the current row value as a hash or throws an INVALID-ITERATORexception if the iterator is invalid
 | 
|  | 
| int | index () | 
|  | returns the current iterator position in the list or -1 if not pointing at a valid element 
 | 
|  | 
| bool | last () | 
|  | returns True if on the last element of the list 
 | 
|  | 
| int | max () | 
|  | returns the number of elements in the list 
 | 
|  | 
| auto | memberGate (string key) | 
|  | This method allows the iterator to be dereferenced directly as a hash for the current row being iterated, as memberGate methods are called implicitly when an unknown member is accessed from outside the class. 
 | 
|  | 
| bool | next () | 
|  | Moves the current position to the next element in the result list; returns False if there are no more elements; if the iterator is not pointing at a valid element before this call, the iterator will be positioned on the first element in the list if the list is not empty. 
 | 
|  | 
| bool | prev () | 
|  | Moves the current position to the previous element in the result list; returns False if there are no more elements; if the iterator is not pointing at a valid element before this call, the iterator will be positioned on the last element in the list if the list is not empty. 
 | 
|  | 
|  | reset () | 
|  | Reset the iterator instance to its initial state. 
 | 
|  | 
| bool | set (int pos) | 
|  | sets the new position in the result list; if the position is invalid then the method returns False, meaning the iterator is not valid, otherwise it returns True 
 | 
|  | 
| bool | valid () | 
|  | returns True if the iterator is currently pointing at a valid element, False if not 
 | 
|  | 
| abstract bool | prev () | 
|  | Moves the current position to the previous element; returns False if there are no more elements. 
 | 
|  | 
| abstract auto | getValue () | 
|  | returns the current value 
 | 
|  | 
| abstract bool | next () | 
|  | Moves the current position to the next element; returns False if there are no more elements. 
 | 
|  | 
| abstract bool | valid () | 
|  | returns True if the iterator is currently pointing at a valid element, False if not 
 | 
|  | 
| abstract bool | empty () | 
|  | returns True if the object to iterate is empty; False if not 
 | 
|  | 
| abstract bool | first () | 
|  | returns True if on the first element 
 | 
|  | 
| abstract bool | last () | 
|  | returns True if on the last element 
 | 
|  | 
This class a reverse iterator class for hashes of lists as returned by Qore::SQL::Datasource::select() and Qore::SQL::DatasourcePool::select(), both of which return hashes with keys giving column names where the key values are lists of column values. 
Like the Qore::HashListIterator class, this class can be used as a more flexible alternative to the context statement, except this class will iterate the result list in reverse order.
Call HashListReverseIterator::next() to iterate through the lists of column values assigned to each hash key in reverse order; do not use the iterator if HashListReverseIterator::next() returns False. A result list can be iterated in reverse order by calling HashListReverseIterator::prev() instead of HashListReverseIterator::next()
- Example: HashListReverseIterator basic usge
- hash<auto> data = { -     "column1": (1, 2, 3,), -     "column2": ("a", "b", "c",), -     "column3": "constant", - }; -   - HashListReverseIterator it(data); - while (it.next()) { -     printf("iter %d: getValue: %y; getKeyValue('column1'): %y\n", -            it.index(), it.getValue(), it.getKeyValue('column1')); - } -   - iter 0: getValue: {column1: 3, column2: "c", column3: "constant"}; getKeyValue('column1'): 3 - iter 1: getValue: {column1: 2, column2: "b", column3: "constant"}; getKeyValue('column1'): 2 - iter 2: getValue: {column1: 1, column2: "a", column3: "constant"}; getKeyValue('column1'): 1 
- Note
- 
- See also
- HashListIterator