mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-22 23:52:03 +00:00
57 lines
1.8 KiB
C++
57 lines
1.8 KiB
C++
#pragma once
|
||
|
||
#include <sstream>
|
||
#include <mysqlxx/Types.h>
|
||
#include <Poco/Exception.h>
|
||
|
||
|
||
namespace mysqlxx
|
||
{
|
||
|
||
/** Общий класс исключений, которые могут быть выкинуты функциями из библиотеки.
|
||
* Функции code() и errnum() возвращают номер ошибки MySQL. (см. mysqld_error.h)
|
||
*/
|
||
struct Exception : public Poco::Exception
|
||
{
|
||
Exception(const std::string & msg, int code = 0) : Poco::Exception(msg, code) {}
|
||
int errnum() const { return code(); }
|
||
const char * name() const throw() { return "mysqlxx::Exception"; }
|
||
const char * className() const throw() { return "mysqlxx::Exception"; }
|
||
};
|
||
|
||
|
||
/// Не удалось соединиться с сервером.
|
||
struct ConnectionFailed : public Exception
|
||
{
|
||
ConnectionFailed(const std::string & msg, int code = 0) : Exception(msg, code) {}
|
||
const char * name() const throw() { return "mysqlxx::ConnectionFailed"; }
|
||
const char * className() const throw() { return "mysqlxx::ConnectionFailed"; }
|
||
};
|
||
|
||
|
||
/// Запрос содержит ошибку.
|
||
struct BadQuery : public Exception
|
||
{
|
||
BadQuery(const std::string & msg, int code = 0) : Exception(msg, code) {}
|
||
const char * name() const throw() { return "mysqlxx::BadQuery"; }
|
||
const char * className() const throw() { return "mysqlxx::BadQuery"; }
|
||
};
|
||
|
||
|
||
/// Невозможно распарсить значение.
|
||
struct CannotParseValue : public Exception
|
||
{
|
||
CannotParseValue(const std::string & msg, int code = 0) : Exception(msg, code) {}
|
||
const char * name() const throw() { return "mysqlxx::CannotParseValue"; }
|
||
const char * className() const throw() { return "mysqlxx::CannotParseValue"; }
|
||
};
|
||
|
||
|
||
std::string errorMessage(MYSQL * driver);
|
||
|
||
/// For internal need of library.
|
||
void checkError(MYSQL * driver);
|
||
void onError(MYSQL * driver);
|
||
|
||
}
|