| 1 | #pragma once |
| 2 | |
| 3 | #include <mysqlxx/ResultBase.h> |
| 4 | #include <mysqlxx/Row.h> |
| 5 | |
| 6 | |
| 7 | namespace mysqlxx |
| 8 | { |
| 9 | |
| 10 | class Connection; |
| 11 | |
| 12 | |
| 13 | /** Результат выполнения запроса, предназначенный для чтения строк, одна за другой. |
| 14 | * В памяти при этом хранится только одна, текущая строка. |
| 15 | * В отличие от StoreQueryResult, произвольный доступ к строкам невозможен, |
| 16 | * а также, при чтении следующей строки, предыдущая становится некорректной. |
| 17 | * Вы обязаны прочитать все строки из результата |
| 18 | * (вызывать функцию fetch(), пока она не вернёт значение, преобразующееся к false), |
| 19 | * иначе при следующем запросе будет выкинуто исключение с текстом "Commands out of sync". |
| 20 | * Объект содержит ссылку на Connection. |
| 21 | * Если уничтожить Connection, то объект становится некорректным и все строки результата - тоже. |
| 22 | * Если задать следующий запрос в соединении, то объект и все строки тоже становятся некорректными. |
| 23 | * Использовать объект можно только для результата одного запроса! |
| 24 | * (При попытке присвоить объекту результат следующего запроса - UB.) |
| 25 | */ |
| 26 | class UseQueryResult : public ResultBase |
| 27 | { |
| 28 | public: |
| 29 | UseQueryResult(MYSQL_RES * res_, Connection * conn_, const Query * query_); |
| 30 | |
| 31 | Row fetch(); |
| 32 | |
| 33 | /// Для совместимости |
| 34 | Row fetch_row() { return fetch(); } |
| 35 | }; |
| 36 | |
| 37 | } |
| 38 | |