最近做项目需要利用c语言对mysql进行获取数据的操作,于是我对mysql社区提供的c语言调用mysql的部分api进行了简单封装,这里做下记录,方便以后回顾。
以下是对mysql操作函数进行了简单封装:
#include
#include
#include"mysql_include/mysql.h"
#include
/************************************************
* @brief 用固定的用户名和密码连接固定的数据库
* @param mysql:数据库句柄
* @return 成功返回0,失败返回-1
* History
* Modified by:
* Date:
* Modification:
************************************************/
int mysql_fun_connect(MYSQL* mysql)
{
if(!mysql_init(mysql))
{
syslog(LOG_ERR,"file:%s,line:%d.Mysql_init error",__FILE__,__LINE__);
return -1;
}
if(!mysql_real_connect(mysql,"127.0.0.1","root","1234","test",0,NULL,0))
{
syslog(LOG_ERR,"file:%s,line:%d.Connecte mysql error",__FILE__,__LINE__);
return -1;
}
return 0;
}
/*对mysql原释放空间的api进行封装,便于函数名统一*/
void mysql_fun_free_res(MYSQL_RES* res)
{
mysql_free_result(res);
}
/*对mysql原关闭数据库连接的api进行封装,便于函数名统一*/
void mysql_fun_close(MYSQL* mysql)
{
syslog(LOG_DEBUG,"file:%s,line:%d.In the mysql_my_close",__FILE__,__LINE__);
mysql_close(mysql);
}
/***********************************************
* @brief 发送mysql客户端指令
* @param mysql:mysql句柄
* command:数据库客户端指令
* @return 成功返回0,失败返回-1
* History
* Modified by:
* Date:
* Modification:
**********************************************/
int mysql_fun_send(MYSQL* mysql,const char* command)
{
int ret = 0;
ret = mysql_query(mysql,command);
if(ret)
{
syslog(LOG_ERR,"file:%s,line:%d.Mysql_query error:%s",__FILE__,__LINE__,mysql_error(mysql));
return -1;
}
return 0;
}
/***********************************************************
* @brief 从数据库中获取结果并将其转化为整数
* @param mysql:数据库句柄
* command:发送给数据库的sql命令
* @return 成功返回整数结果,错误返回-1
* History
* Modified by:
* Date:
* Modification:
***********************************************************/
int mysql_fun_get_int_res(MYSQL* mysql,const char* command)
{
MYSQL_RES* res = NULL;
MYSQL_ROW row;
int ret = 0;
ret = mysql_query(mysql,command);
if(ret)
syslog(LOG_ERR,"file:%s,line:%d.Mysql query error:%s",__FILE__,__LINE__,mysql_error(mysql));
else
{
res = mysql_store_result(mysql);
if(res)
{
row = mysql_fetch_row(res);
if(row && (*row))
{
mysql_fun_free_res(res);
res = NULL;
return ((int)atoi(*row));
}
mysql_fun_free_res(res);
res = NULL;
}
if(mysql_errno(mysql))
syslog(LOG_ERR,"file:%s,line:%d.Retrive error:%s",__FILE__,__LINE__,mysql_error(mysql));
}
return -1;
}
/*****************************************************************
* @brief 从数据库中获取字符串结果
* @param mysql:数据库句柄
* command:符合要求的mysql客户端指令
* str:接收结果的字符串空间指针
* @return 成功返回空间首地址,失败返回空
* History
* Modified by:
* Date:
* Modification:
*****************************************************************/
char* mysql_fun_get_char_res(MYSQL* mysql,char* command,char* str)
{
MYSQL_RES* res = NULL;
MYSQL_ROW row;
int ret = 0;
ret = mysql_query(mysql,command);
if(ret)
syslog(LOG_ERR,"file:%s,line:%d.Mysql_query error",__FILE__,__LINE__);
else
{
res = mysql_store_result(mysql);
if(res)
{
row = mysql_fetch_row(res);
if(row && (*row)) //必须有内容且内容不为空,缺少内容不为空的判断可能会造成段错误
{
strcpy(str,*row);
mysql_fun_free_res(res);
res = NULL;
return str;
}
mysql_fun_free_res(res); //缺少该处可能会造成内存泄漏
res = NULL;
}
if(mysql_errno(mysql))
syslog(LOG_ERR,"file:%s,line:%d.Retrive error:%s",__FILE__,__LINE__,mysql_error(mysql));
}
return NULL;
}
/****************************************************
* @brief 获取结果集中结果的数量
* @param mysql:数据库句柄
* command:数据库指令
* @return 成功返回结果集数量,失败返回-1
* History
* Modified by:
* Date:
* Modification:
***************************************************/
int mysql_fun_get_num(MYSQL* mysql,char* command)
{
MYSQL_RES* res = NULL;
int ret = 0;
int num = 0;
ret = mysql_query(mysql,command);
if(ret)
{
syslog(LOG_ERR,"file:%s,line:%d.selected error:%s",__FILE__,__LINE__,mysql_error(mysql));
return -1;
}
res = mysql_store_result(mysql);
if(res)
{
num = (int)mysql_num_rows(res);
mysql_fun_free_res(res);
res = NULL;
}
return num;
}