mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2024-11-08 16:57:16 +01:00
121 lines
3.6 KiB
C++
121 lines
3.6 KiB
C++
// ------------------------------------------------------------------------------------------------
|
|
#include "Connection.hpp"
|
|
#include "Statement.hpp"
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
namespace SqMod {
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
SQInteger Connection::Typename(HSQUIRRELVM vm)
|
|
{
|
|
static const SQChar name[] = _SC("SqMySQLConnection");
|
|
sq_pushstring(vm, name, sizeof(name));
|
|
return 1;
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
Int32 Connection::Cmp(const Connection & o) const
|
|
{
|
|
if (m_Handle == o.m_Handle)
|
|
{
|
|
return 0;
|
|
}
|
|
else if (m_Handle.HndPtr() > o.m_Handle.HndPtr())
|
|
{
|
|
return 1;
|
|
}
|
|
else
|
|
{
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
CSStr Connection::ToString() const
|
|
{
|
|
// Do we have a valid handle?
|
|
if (m_Handle)
|
|
{
|
|
ToStringF("%s:%s@%s:%u", m_Handle->mUser.c_str(), m_Handle->mPass.c_str(),
|
|
m_Handle->mHost.c_str(), m_Handle->mPort);
|
|
}
|
|
// Default to an epty string
|
|
return _SC("");
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
void Connection::SetName(CSStr name)
|
|
{
|
|
// Validate the managed handle
|
|
m_Handle.Validate();
|
|
// Attempt to select the database with the given name
|
|
if (mysql_select_db(m_Handle, name) != 0)
|
|
{
|
|
THROW_CURRENT(m_Handle, "Cannot select database");
|
|
}
|
|
// Remember the database name
|
|
m_Handle->mName.assign(name);
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
void Connection::SetCharset(CSStr charset)
|
|
{
|
|
// Validate the managed handle
|
|
m_Handle.Validate();
|
|
// Attempt to Set the default character set for the managed connection
|
|
if (mysql_set_character_set(m_Handle, charset) != 0)
|
|
{
|
|
THROW_CURRENT(m_Handle, "Cannot apply character set");
|
|
}
|
|
// Remember the character set
|
|
m_Handle->mCharset.assign(charset);
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
void Connection::SetAutoCommit(bool toggle)
|
|
{
|
|
// Validate the managed handle
|
|
m_Handle.Validate();
|
|
// Attempt to toggle auto-commit if necessary
|
|
if (m_Handle->mAutoCommit != toggle && mysql_autocommit(m_Handle, toggle) != 0)
|
|
{
|
|
THROW_CURRENT(m_Handle, "Cannot toggle auto-commit");
|
|
}
|
|
else
|
|
{
|
|
m_Handle->mAutoCommit = toggle;
|
|
}
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
SQInteger Connection::Execute(CSStr query)
|
|
{
|
|
// Validate the managed handle
|
|
m_Handle.Validate();
|
|
// Perform the requested operation
|
|
return m_Handle->Execute(query);
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
SQInteger Connection::Insert(CSStr /*query*/)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
SQInteger Connection::Query(CSStr /*query*/)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
Statement Connection::GetStatement(CSStr query)
|
|
{
|
|
// Validate the managed handle
|
|
m_Handle.Validate();
|
|
// Return the requested information
|
|
return Statement(m_Handle, query);
|
|
}
|
|
|
|
} // Namespace:: SqMod
|