ClickHouse/libs/libmysqlxx/src/Query.cpp

96 lines
1.7 KiB
C++

#include <mysqlxx/Connection.h>
#include <mysqlxx/Query.h>
namespace mysqlxx
{
Query::Query(Connection * conn_, const std::string & query_string) : std::ostream(0), conn(conn_)
{
/// Важно в случае, если Query используется не из того же потока, что Connection.
my_thread_init();
init(&query_buf);
if (!query_string.empty())
{
query_buf.str(query_string);
seekp(0, std::ios::end);
}
imbue(std::locale::classic());
}
Query::Query(const Query & other) : std::ostream(0), conn(other.conn)
{
/// Важно в случае, если Query используется не из того же потока, что Connection.
my_thread_init();
init(&query_buf);
imbue(std::locale::classic());
*this << other.str();
}
Query & Query::operator= (const Query & other)
{
conn = other.conn;
seekp(0);
clear();
*this << other.str();
return *this;
}
Query::~Query()
{
my_thread_end();
}
void Query::reset()
{
seekp(0);
clear();
query_buf.str("");
}
void Query::executeImpl()
{
std::string query_string = query_buf.str();
if (mysql_real_query(conn->getDriver(), query_string.data(), query_string.size()))
throw BadQuery(errorMessage(conn->getDriver()), mysql_errno(conn->getDriver()));
}
UseQueryResult Query::use()
{
executeImpl();
MYSQL_RES * res = mysql_use_result(conn->getDriver());
if (!res)
onError(conn->getDriver());
return UseQueryResult(res, conn, this);
}
StoreQueryResult Query::store()
{
executeImpl();
MYSQL_RES * res = mysql_store_result(conn->getDriver());
if (!res)
checkError(conn->getDriver());
return StoreQueryResult(res, conn, this);
}
void Query::execute()
{
executeImpl();
}
UInt64 Query::insertID()
{
return mysql_insert_id(conn->getDriver());
}
}