⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cdatabase.cpp

📁 mysql C API 封装类, 主要功能为建立与关闭MySql数据库连接
💻 CPP
字号:
#include "CDataBase.h"

CDataBase::CDataBase(const char *host, const char *user, const char *passwd, const char *db): 
	m_host(host), m_user(user), m_passwd(passwd), m_db(db), m_bConn(false), m_ErrMsg(NULL)
{
	if (mysql_init(&m_mysql) && mysql_real_connect(&m_mysql, m_host, m_user, m_passwd, m_db, MYSQL_PORT, NULL, 0))
	{
		//printf("Connect to MySQL Server Successfully!\n");
		m_bConn = true;
	}
	else
	{
		//printf("Failed to connect MySQL Server! [Error]: %s\n", mysql_error(&m_mysql));
		m_ErrMsg = mysql_error(&m_mysql);
		mysql_close(&m_mysql);
	}
}

CDataBase::~CDataBase()
{
	if (m_bConn)
	{
		mysql_close(&m_mysql);
		m_bConn = false;
	}
}

bool CDataBase::ExecuteSql(const char* sql)
{
	if (!m_bConn)
	{
		return false;
	}
	if (mysql_real_query(&m_mysql, sql, (unsigned long)strlen(sql)) == 0)
	{
		//printf("'%s'   Query successfully!\n", sql);
		return true;
	}
	else
	{
		//printf("'%s'  [Error]: %s\n", sql, mysql_error(&m_mysql));
		m_ErrMsg = mysql_error(&m_mysql);
		return false;
	}
}

MYSQL_RES* CDataBase::StoreResult()
{
	MYSQL_RES* res = NULL;
	if((res = mysql_store_result(&m_mysql)) != NULL)
	{
		return res;
	}
	else
	{
		//printf("Failed to store result!\n");
		return false;
	}
}

void CDataBase::FreeResult(MYSQL_RES *res)
{
	if (res)
	{
		mysql_free_result(res);
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -