1
Fork 0
mirror of https://github.com/SapphireServer/Sapphire.git synced 2025-04-20 11:47:47 +00:00
sapphire/deps/mysqlConnector/Connection.h

89 lines
2.1 KiB
C
Raw Normal View History

#ifndef SAPPHIRE_CONNECTION_H
#define SAPPHIRE_CONNECTION_H
#include <memory>
#include <mysql.h>
#include <map>
namespace Mysql
{
using optionMap = std::map< enum mysql_option, std::string >;
class MySqlBase;
class Statement;
class PreparedStatement;
class Connection : public std::enable_shared_from_this< Connection >
{
public:
Connection( std::shared_ptr< MySqlBase > pBase,
const std::string& hostName,
const std::string& userName,
const std::string& password,
uint16_t port = 3306);
Connection( std::shared_ptr< MySqlBase > pBase,
const std::string& hostName,
const std::string& userName,
const std::string& password,
const optionMap& options,
uint16_t port = 3306 );
virtual ~Connection();
void close();
bool isClosed() const;
bool ping();
void setOption( enum mysql_option option, const void* arg );
void setOption( enum mysql_option option, uint32_t arg );
void setOption( enum mysql_option option, const std::string& arg );
std::shared_ptr< MySqlBase > getMySqlBase() const;
void setAutoCommit( bool autoCommit );
bool getAutoCommit();
std::string escapeString( const std::string& inData );
void setSchema( const std::string& catalog );
std::shared_ptr< Statement > createStatement();
void beginTransaction();
void commitTransaction();
void rollbackTransaction();
std::string getSchema();
std::string getError();
uint32_t getErrorNo();
bool isReadOnly();
void setReadOnly( bool readOnly );
bool isValid();
bool reconnect();
std::shared_ptr< Mysql::PreparedStatement > prepareStatement( const std::string& sql );
std::string getLastStatementInfo();
MYSQL* getRawCon();
private:
std::shared_ptr< MySqlBase > m_pBase;
MYSQL* m_pRawCon;
bool m_bConnected;
Connection( const Connection& );
void operator=( Connection& );
};
}
#endif //SAPPHIRE_CONNECTION_H