mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-10-25 18:00:51 +00:00
46 lines
2.1 KiB
C++
46 lines
2.1 KiB
C++
|
#pragma once
|
|||
|
|
|||
|
#include <vector>
|
|||
|
|
|||
|
#include <mysqlxx/ResultBase.h>
|
|||
|
#include <mysqlxx/Row.h>
|
|||
|
|
|||
|
|
|||
|
namespace mysqlxx
|
|||
|
{
|
|||
|
|
|||
|
class Connection;
|
|||
|
|
|||
|
|
|||
|
/** Результат выполнения запроса, загруженный полностью на клиента.
|
|||
|
* Это требует оперативку, чтобы вместить весь результат,
|
|||
|
* но зато реализует произвольный доступ к строкам по индексу.
|
|||
|
* Если размер результата большой - используйте лучше UseQueryResult.
|
|||
|
* Объект содержит ссылку на Connection.
|
|||
|
* Если уничтожить Connection, то объект становится некорректным и все строки результата - тоже.
|
|||
|
* Если задать следующий запрос в соединении, то объект и все строки тоже становятся некорректными.
|
|||
|
* Использовать объект можно только для результата одного запроса!
|
|||
|
* (При попытке присвоить объекту результат следующего запроса - UB.)
|
|||
|
*/
|
|||
|
class StoreQueryResult : public std::vector<Row>, public ResultBase
|
|||
|
{
|
|||
|
public:
|
|||
|
StoreQueryResult(MYSQL_RES * res_, Connection * conn_, const Query * query_);
|
|||
|
|
|||
|
size_t num_rows() const { return size(); }
|
|||
|
|
|||
|
private:
|
|||
|
|
|||
|
/** Не смотря на то, что весь результат выполнения запроса загружается на клиента,
|
|||
|
* и все указатели MYSQL_ROW на отдельные строки различные,
|
|||
|
* при этом функция mysql_fetch_lengths() возвращает длины
|
|||
|
* для текущей строки по одному и тому же адресу.
|
|||
|
* То есть, чтобы можно было пользоваться несколькими Row одновременно,
|
|||
|
* необходимо заранее куда-то сложить все длины.
|
|||
|
*/
|
|||
|
typedef std::vector<MYSQL_LENGTH> Lengths;
|
|||
|
Lengths lengths;
|
|||
|
};
|
|||
|
|
|||
|
}
|