source-engine/utils/sqlwrapper/sqlhelpers.h

163 lines
4.9 KiB
C
Raw Permalink Normal View History

2020-04-22 16:56:21 +00:00
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//=============================================================================
#include "utlvector.h"
extern "C"
{
#include <WinSock.H>
#include "mysql.h"
};
#include "utlvector.h"
typedef enum_field_types ESQLFieldType;
//-----------------------------------------------------------------------------
// Purpose: helper interface for running queries internal to this dll
//-----------------------------------------------------------------------------
class ISQLHelper
{
public:
// run a sql query on the db
virtual bool BInternalQuery( const char *pchQueryString, MYSQL_RES **ppMySQLRes, bool bRecurse = true ) = 0;
};
//-----------------------------------------------------------------------------
// Purpose: represents the data about a single SQL column
//-----------------------------------------------------------------------------
class CSQLColumn
{
public:
CSQLColumn() { m_rgchName[0] = 0; }
CSQLColumn( const char *pchName, ESQLFieldType eSQLFieldType );
virtual const char *PchColumnName() const { return m_rgchName; };
virtual EColumnType GetEColumnType() const { return m_EColumnType; };
virtual ESQLFieldType GetESQLFieldType() const { return m_ESQLFieldType; };
private:
char m_rgchName[64];
EColumnType m_EColumnType;
ESQLFieldType m_ESQLFieldType;
};
//-----------------------------------------------------------------------------
// Purpose: encapsulates a table's description
//-----------------------------------------------------------------------------
class CSQLTable : public ISQLTable
{
public:
CSQLTable( const char *pchName );
CSQLTable( CSQLTable const &CSQLTable ); // copy constructor
void AddColumn( const char *pchName, ESQLFieldType ESQLFieldType );
const char *PchName() const { return m_rgchName; };
virtual int GetCSQLColumn() const { return m_VecSQLColumn.Count(); };
virtual const char *PchColumnName( int iSQLColumn ) const { return m_VecSQLColumn[iSQLColumn].PchColumnName(); };
virtual EColumnType GetEColumnType( int iSQLColumn ) const { return m_VecSQLColumn[iSQLColumn].GetEColumnType(); };
virtual ESQLFieldType GetESQLFieldType( int iSQLColumn ) const { return m_VecSQLColumn[iSQLColumn].GetESQLFieldType(); };
void Reset() { m_VecSQLColumn.RemoveAll(); }
#ifdef DBGFLAG_VALIDATE
void Validate( CValidator &validator, char *pchName );
#endif
private:
char m_rgchName[64];
CUtlVector<CSQLColumn> m_VecSQLColumn;
};
//-----------------------------------------------------------------------------
// Purpose: encapsulates a db's worth of tables
//-----------------------------------------------------------------------------
class CSQLTableSet : public ISQLTableSet
{
public:
CSQLTableSet() { m_bInit = false; }
bool Init( ISQLHelper *pISQLHelper );
bool BInit() { return m_bInit; }
virtual int GetCSQLTable() const { return m_VecSQLTable.Count(); };
virtual const ISQLTable *PSQLTable( int iSQLTable ) const;
#ifdef DBGFLAG_VALIDATE
void Validate( CValidator &validator, char *pchName );
#endif
private:
static EColumnType EColumnTypeFromPchName( const char *pchName );
CUtlVector<CSQLTable> m_VecSQLTable;
bool m_bInit;
};
//-----------------------------------------------------------------------------
// Purpose: describes a single row in a result set
//-----------------------------------------------------------------------------
class CSQLRow : public ISQLRow
{
public:
CSQLRow( MYSQL_ROW *pMySQLRow, const ISQLTable *pSQLTableDescription, int cSQLRowData );
~CSQLRow();
virtual int GetCSQLRowData() const { return m_VecSQLRowData.Count(); };
virtual const char *PchData( int iSQLRowData ) const;
virtual int NData( int iSQLRowData ) const;
virtual uint64 UlData( int iSQLRowData ) const;
virtual float FlData( int iSQLRowData ) const;
virtual uint64 UlTime( int iSQLRowData ) const;
virtual bool BData( int iSQLRowData ) const;
virtual EColumnType GetEColumnType( int iSQLRowData ) const;
#ifdef DBGFLAG_VALIDATE
void Validate( CValidator &validator, char *pchName );
#endif
private:
struct SQLRowData_s
{
union
{
int nData;
float flData;
const char *pchData;
uint64 ulTime;
uint64 ulData;
} data;
EColumnType eColumnType;
};
CUtlVector<struct SQLRowData_s> m_VecSQLRowData;
CUtlVector<char *> m_VecPchStoredStrings;
};
//-----------------------------------------------------------------------------
// Purpose: encapsulates a result set from a SQL query
//-----------------------------------------------------------------------------
class CResultSet : public IResultSet
{
public:
CResultSet();
~CResultSet();
bool Query( const char *pchQuery, ISQLHelper *pISQLHelper );
virtual int GetCSQLRow() const;
virtual const ISQLRow *PSQLRowNextResult();
void FreeResult();
#ifdef DBGFLAG_VALIDATE
void Validate( CValidator &validator, char *pchName );
#endif
private:
MYSQL_RES *m_MySQLRes;
CSQLRow *m_pSQLRow;
CSQLTable m_SQLTableDescription;
int m_cSQLField;
int m_cSQLRow;
};