Represents a database result set.
A ResultSet is created by executing a SQL SELECT statement using Connection::executeQuery().
A ResultSet maintains a cursor pointing to its current row of data. Initially, the cursor is positioned before the first row. ResultSet::next() moves the cursor to the next row, and because it returns false when there are no more rows, it can be used in a while loop to iterate through the result set. A ResultSet is not updatable and has a cursor that moves forward only. Thus, you can iterate through it only once and only from the first row to the last row.
The ResultSet class provides getter methods for retrieving column values from the current row. Values can be retrieved using either the index number of the column or the name of the column. In general, using the column index will be more efficient. Columns are numbered from 1.
Column names used as input to getter methods are case sensitive. When a getter method is called with a column name and several columns have the same name, the value of the first matching column will be returned. The column name option is designed to be used when column names are used in the SQL query that generated the result set. For columns that are NOT explicitly named in the query, it is best to use column indices.
The following examples demonstrate how to obtain a ResultSet and how to retrieve values from it.
In this example, columns are named in the SELECT statement, and we retrieve values using the column names (we could of course also use indices if we want):
This example demonstrates selecting a generated result and printing it. When the SELECT statement doesn't name the column, we use the column index to retrieve the value:
A ResultSet stores values internally as bytes and converts values on-the-fly to numeric types when requested, such as when getInt() or one of the other numeric get-methods are called. In the above example, even if count(*) returns a numeric value, we can use getString() to get the number as a string or if we choose, we can use getInt() to get the value as an integer. In the latter case, note that if the column value cannot be converted to a number, an sql_exception is thrown.
ResultSet provides two principal methods for retrieving temporal column values as C types. getTimestamp() converts a SQL timestamp value to a time_t
and getDateTime() returns a tm structure
representing a Date, Time, DateTime, or Timestamp column type. To get a temporal column value as a string, simply use getString()
A ResultSet is reentrant, but not thread-safe and should only be used by one thread (at a time).
Public Member Functions | |
Properties | |
int | columnCount () const noexcept |
Gets the number of columns in this ResultSet. | |
std::optional< std::string_view > | columnName (int columnIndex) const noexcept |
Gets the designated column's name. | |
long | columnSize (int columnIndex) |
Gets the size of a column in bytes. | |
void | setFetchSize (int rows) noexcept |
Sets the number of rows to fetch from the database. | |
int | getFetchSize () const noexcept |
Gets the number of rows to fetch from the database. | |
Functions | |
bool | next () |
Moves the cursor to the next row. | |
Columns | |
bool | isNull (int columnIndex) |
Checks if the designated column's value is SQL NULL. | |
std::optional< std::string_view > | getString (int columnIndex) |
Gets the designated column's value as a string. | |
std::optional< std::string_view > | getString (const std::string &columnName) |
Gets the designated column's value as a string. | |
int | getInt (int columnIndex) |
Gets the designated column's value as an int. | |
int | getInt (const std::string &columnName) |
Gets the designated column's value as an int. | |
long long | getLLong (int columnIndex) |
Gets the designated column's value as a long long. | |
long long | getLLong (const std::string &columnName) |
Gets the designated column's value as a long long. | |
double | getDouble (int columnIndex) |
Gets the designated column's value as a double. | |
double | getDouble (const std::string &columnName) |
Gets the designated column's value as a double. | |
std::optional< std::span< const std::byte > > | getBlob (int columnIndex) |
Gets the designated column's value as a byte span. | |
std::optional< std::span< const std::byte > > | getBlob (const std::string &columnName) |
Gets the designated column's value as a byte span. | |
Date and Time | |
time_t | getTimestamp (int columnIndex) |
Gets the designated column's value as a Unix timestamp. | |
time_t | getTimestamp (const std::string &columnName) |
Gets the designated column's value as a Unix timestamp. | |
tm | getDateTime (int columnIndex) |
Gets the designated column's value as a Date, Time or DateTime. | |
tm | getDateTime (const std::string &columnName) |
Gets the designated column's value as a Date, Time or DateTime. | |
|
nodiscardnoexcept |
Gets the number of columns in this ResultSet.
|
nodiscardnoexcept |
Gets the designated column's name.
columnIndex | The first column is 1, the second is 2, ... |
|
nodiscard |
Gets the size of a column in bytes.
If the column is a blob then this method returns the number of bytes in that blob. No type conversions occur. If the result is a string (or a number since a number can be converted into a string) then return the number of bytes in the resulting string.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If columnIndex is outside the valid range. |
|
noexcept |
|
nodiscardnoexcept |
Gets the number of rows to fetch from the database.
Unless previously set with setFetchSize(), the returned value is the same as returned by Connection::getFetchSize()
bool next | ( | ) |
Moves the cursor to the next row.
A ResultSet cursor is initially positioned before the first row; the first call to this method makes the first row the current row; the second call makes the second row the current row, and so on. When there are no more available rows false is returned. An empty ResultSet will return false on the first call to ResultSet::next().
sql_exception | If a database access error occurs. |
|
nodiscard |
Checks if the designated column's value is SQL NULL.
A ResultSet returns an optional for reference types and 0 for value types. Use this method if you need to differentiate between SQL NULL and std::nullopt/0.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database access error occurs or columnIndex is invalid. |
|
nodiscard |
Gets the designated column's value as a string.
The returned string may only be valid until the next call to next() and if you plan to use the returned value longer, you must make a copy.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database access error occurs or columnIndex is invalid. |
|
nodiscard |
Gets the designated column's value as a string.
The returned string may only be valid until the next call to next() and if you plan to use the returned value longer, you must make a copy.
columnName | The SQL name of the column. case-sensitive. |
sql_exception | If a database access error occurs or columnName does not exist. |
|
nodiscard |
Gets the designated column's value as an int.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database error occurs, columnIndex is invalid or value is NaN. |
|
nodiscard |
Gets the designated column's value as an int.
columnName | The SQL name of the column. case-sensitive. |
sql_exception | If a database error occurs, columnName is invalid or value is NaN. |
|
nodiscard |
Gets the designated column's value as a long long.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database error occurs, columnIndex is invalid or value is NaN. |
|
nodiscard |
Gets the designated column's value as a long long.
columnName | The SQL name of the column. case-sensitive. |
sql_exception | If a database error occurs, columnName is invalid or value is NaN. |
|
nodiscard |
Gets the designated column's value as a double.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database error occurs, columnIndex is invalid or value is NaN. |
|
nodiscard |
Gets the designated column's value as a double.
columnName | The SQL name of the column. case-sensitive. |
sql_exception | If a database error occurs, columnName is invalid or value is NaN. |
|
nodiscard |
Gets the designated column's value as a byte span.
The returned blob may only be valid until the next call to next() and if you plan to use the returned value longer, you must make a copy.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database access error occurs or columnIndex is invalid. |
|
nodiscard |
Gets the designated column's value as a byte span.
The returned blob may only be valid until the next call to next() and if you plan to use the returned value longer, you must make a copy.
columnName | The SQL name of the column. case-sensitive. |
sql_exception | If a database access error occurs or columnName is invalid. |
|
nodiscard |
Gets the designated column's value as a Unix timestamp.
The returned value is in Coordinated Universal Time (UTC) and represents seconds since the epoch (January 1, 1970, 00:00:00 GMT).
Even though the underlying database might support timestamp ranges before the epoch and after '2038-01-19 03:14:07 UTC' it is safest not to assume or use values outside this range. Especially on a 32-bit system.
SQLite does not have temporal SQL data types per se and using this method with SQLite assumes the column value in the Result Set to be either a numerical value representing a Unix Time in UTC which is returned as-is or an ISO 8601 time string which is converted to a time_t
value.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database access error occurs, columnIndex is outside the valid range or if the column value cannot be converted to a valid timestamp. |
|
nodiscard |
Gets the designated column's value as a Unix timestamp.
The returned value is in Coordinated Universal Time (UTC) and represents seconds since the epoch (January 1, 1970, 00:00:00 GMT).
Even though the underlying database might support timestamp ranges before the epoch and after '2038-01-19 03:14:07 UTC' it is safest not to assume or use values outside this range. Especially on a 32-bit system.
SQLite does not have temporal SQL data types per se and using this method with SQLite assumes the column value in the Result Set to be either a numerical value representing a Unix Time in UTC which is returned as-is or an ISO 8601 time string which is converted to a time_t
value.
columnName | The SQL name of the column. case-sensitive. |
sql_exception | If a database access error occurs, columnName is not found or if the column value cannot be converted to a valid timestamp. |
|
nodiscard |
Gets the designated column's value as a Date, Time or DateTime.
This method can be used to retrieve the value of columns with the SQL data type, Date, Time, DateTime or Timestamp. The returned tm
structure follows the convention for usage with mktime(3) where:
If the column value contains timezone information, tm_gmtoff is set to the offset from UTC in seconds, otherwise tm_gmtoff is set to 0. On systems without tm_gmtoff, (Solaris), the member, tm_wday is set to gmt offset instead as this property is ignored by mktime on input. The exception to the above is tm_year which contains the year literal and not years since 1900 which is the convention. All other fields in the structure are set to zero. If the column type is DateTime or Timestamp all the fields mentioned above are set, if it is a Date or a Time, only the relevant fields are set.
columnIndex | The first column is 1, the second is 2, ... |
sql_exception | If a database access error occurs, columnIndex is outside the valid range or if the column value cannot be converted to a valid SQL Date, Time or DateTime type. |
|
nodiscard |
Gets the designated column's value as a Date, Time or DateTime.
This method can be used to retrieve the value of columns with the SQL data type, Date, Time, DateTime or Timestamp. The returned tm
structure follows the convention for usage with mktime(3) where:
If the column value contains timezone information, tm_gmtoff is set to the offset from UTC in seconds, otherwise tm_gmtoff is set to 0. On systems without tm_gmtoff, (Solaris), the member, tm_wday is set to gmt offset instead as this property is ignored by mktime on input. The exception to the above is tm_year which contains the year literal and not years since 1900 which is the convention. All other fields in the structure are set to zero. If the column type is DateTime or Timestamp all the fields mentioned above are set, if it is a Date or a Time, only the relevant fields are set.
columnName | The SQL name of the column. case-sensitive. |
sql_exception | If a database access error occurs, columnName is not found or if the column value cannot be converted to a valid Date, Time or DateTime type. |
Copyright © Tildeslash Ltd. All rights reserved.