C语言定义的操作mysql数据库的接口
编写的环境:centos7系统下,对mysql的衍生mariadb进行数据库的操作,包含设置访问数据库的参数,查询数据库和增删改数据库的三个功能。对于查询数据库,我这里允许不返回查询结果,用于判断查询是否成功的功能编写上。
先上头文件
/* 该文件用于描述访问数据库的接口声明 */
#ifndef _OPERATE_DB_H_
#define _OPERATE_DB_H_
//#include <winsock.h> /* windows系统要加上这个 */
#include <mysql.h>
#include "status.h" /*
* 访问数据库的字符串的最大长度
*/
#define QUERY_MAX_SIZE 1024 /*
* 设置访问数据库参数
* _localhost -- 访问数据库的主机名
* _userName -- 访问数据库的用户名
* _password -- 对应的密码
* _databaseName -- 要操作的数据库名字
* 返回结果状态值,如果没有异常返回OK;否则返回ERROR
*/
STATUS
InitDbParms( char const *_localhost, char const *_userName, char const *_password, char const *_databaseName ); /*
* 操作数据库
* commandString -- 存放SQL操作命令
* 如果操作成功返回OK;否则返回ERROR
*/
STATUS
UpdateDatabase( char const *commandString ); /*
* 查询数据库
* commandString -- 查询sql命令
* resultp -- 指向存放查询结果的双指针(如果传递给该参数NULL,则函数不会返回查询结果)
* 返回结果状态值,如果操作成功返回OK;否则返回ERROR
*/
STATUS
QueryDatabase( char const *commandString, MYSQL_RES **resultpp ); /*
** 释放掉mysql查询的结果所占内存
**
** storagepp -- 指向存放结果的内存的双指针
** 返回空。
*/
void
FreeTheSearchStorage(MYSQL_RES **storagepp);
#endif
再上接口文件
/* 该文件用于描述访问数据库的接口声明 */
#ifndef _OPERATE_DB_H_
#define _OPERATE_DB_H_
#include <mysql.h>
#include "status.h" /*
* 访问数据库的字符串的最大长度
*/
#define QUERY_MAX_SIZE 1024 /*
* 设置访问数据库参数
* _localhost -- 访问数据库的主机名
* _userName -- 访问数据库的用户名
* _password -- 对应的密码
* _databaseName -- 要操作的数据库名字
* 返回结果状态值,如果没有异常返回OK;否则返回ERROR
*/
STATUS
InitDbParms( char const *_localhost, char const *_userName, char const *_password, char const *_databaseName ); /*
* 操作数据库
* commandString -- 存放SQL操作命令
* 如果操作成功返回OK;否则返回ERROR
*/
STATUS
UpdateDatabase( char const *commandString ); /*
* 查询数据库
* commandString -- 查询sql命令
* resultp -- 指向存放查询结果的双指针(如果传递给该参数NULL,则函数不会返回查询结果)
* 返回结果状态值,如果操作成功返回OK;否则返回ERROR
*再上接口定义
#include <stdio.h>
#include <stdlib.h>
//#include <winsock.h> /* windows系统要加上这个 */
#include <mysql.h>
#include "operateDb.h"
#include "status.h" /*
* 内部数据
*/
static char const *localhost = NULL; //主机名
static char const *userName = NULL; //mysql用户名
static char const *password = NULL; //它的密码
static char const *databaseName = NULL; //所要操作的数据库 /*
* 外部接口
*
*
* 设置访问数据库参数
* _localhost -- 访问数据库的主机名
* _userName -- 访问数据库的用户名
* _password -- 对应的密码
* _databaseName -- 要操作的数据库名字
* 返回结果状态值,如果没有异常返回OK;否则返回ERROR
*/
STATUS
InitDbParms( char const *_localhost, char const *_userName, char const *_password, char const *_databaseName )
{
if(_localhost == NULL) //检查参数是否有效
{
fprintf(stdout, "传递给函数InitDbParms的参数_localhost无效。\n");
return ERROR;
}
if(_userName == NULL)
{
fprintf(stdout, "传递给函数InitDbParms的参数_userName无效。\n");
return ERROR;
}
if(_databaseName == NULL)
{
fprintf(stdout, "传递给函数InitDbParms的参数_databaseName无效。\n");
return ERROR;
} localhost = _localhost;
userName = _userName;
password = _password;
databaseName = _databaseName;
return OK;
} /*
* 操作数据库
* commandString -- 存放SQL操作命令
* 如果操作成功返回OK;否则返回ERROR
*/
STATUS
UpdateDatabase( char const *commandString )
{
MYSQL the_conn; if(commandString == NULL) //检查参数是否有效
{
fprintf(stdout, "传递给函数UpdateDatabase的参数commandString无效。\n");
return ERROR;
} if( mysql_init( &the_conn ) == NULL ) //获取本次连接的句柄
{
fprintf(stdout, "Error at mysql_init().\n");
exit( EXIT_FAILURE );
} if( mysql_real_connect( &the_conn, localhost, userName, password, databaseName, MYSQL_PORT, NULL, 0 ) == NULL ) //连接数据库
{
fprintf(stdout, "Error at mysql_real_connect().\n");
exit( EXIT_FAILURE );
} if( mysql_query( &the_conn, commandString ) != 0 ) //操作数据库
{
fprintf(stdout, "Error at mysql_query().\n");
exit(EXIT_FAILURE);
}
mysql_close( &the_conn ); //断开连接
return OK;
} /*
* 查询数据库
* commandString -- 查询sql命令
* resultpp -- 指向存放查询结果的双指针,注意,如果该参数为NULL,则程序不返回查询的结果。
* 返回结果状态值,如果操作成功返回OK;否则返回ERROR
*/
STATUS
QueryDatabase( char const *commandString, MYSQL_RES **resultpp )
{
MYSQL the_conn;
MYSQL_RES *resultp = NULL; if(commandString == NULL) //检查参数是否有效
{
fprintf(stdout, "传递给函数QueryDatabase的参数commandString无效。\n");
return ERROR;
} if(mysql_init( &the_conn ) == NULL) //获取本次连接的句柄
{
fprintf(stdout, "Error at mysql_init().\n");
exit( EXIT_FAILURE );
} if(mysql_real_connect( &the_conn, localhost, userName, password, databaseName, MYSQL_PORT, NULL, 0 ) == NULL) //连接数据库
{
fprintf(stdout, "Error at mysql_real_connect().\n");
exit( EXIT_FAILURE );
} if(mysql_query( &the_conn, commandString ) != 0) //操作数据库
{
fprintf(stdout, "Error at mysql_query().\n");
exit( EXIT_FAILURE );
} resultp = mysql_store_result(&the_conn); //获取查询结果
mysql_close(&the_conn); //断开连接 if( mysql_num_rows(resultp) != 0 ) //如果查询结果个数不为0
{
if(resultpp == NULL) //判断是否需要返回查询结果
{
mysql_free_result(resultp);
}
else
{
*resultpp = resultp; //返回查询结果
}
return OK;
}
else
{
if(resultpp == NULL)
{
mysql_free_result(resultp);
}
else
{
*resultpp = resultp;
resultp = NULL;
}
return ERROR;
}
} /*
** 释放掉mysql查询的结果所占内存
**
** storagepp -- 指向存放结果的内存的双指针
** 返回空。
*/
void
FreeTheSearchStorage(MYSQL_RES **storagepp)
{
MYSQL_RES *storagep = NULL; if(storagepp != NULL)
{
storagep = *storagepp;
if(storagep != NULL)
{
mysql_free_result(storagep);
storagep = NULL;
*storagepp = storagep;
}
}
}
C语言定义的操作mysql数据库的接口的更多相关文章
- Go语言操作MySQL数据库
Go语言操作MySQL数据库 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品.MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用 ...
- 使用Go语言操作MySQL数据库的思路与步骤
最近在做注册登录服务时,学习用Go语言操作MySQL数据库实现用户数据的增删改查,现将个人学习心得总结如下,另外附有代码仓库地址,欢迎各位有兴趣的fork. 软件环境:Goland.Navicat f ...
- c语言操作mysql数据库
c语言操作Mysql数据库,主要就是为了实现对数据库的增.删.改.查等操作,操作之前,得先连接数据库啊,而连接数据库主要有两种方法.一.使用mysql本身提供的API,在mysql的安装目录中可可以看 ...
- php笔记08:数据库编程---使用php的MySQL扩展库操作MySQL数据库
1.使用php的MySQL扩展库操作MySQL数据库: php有3种方式操作MySQL数据库 (1)mysql扩展库 (2)mysqli扩展库 (3)pdo mysql扩展库与mysql数据库 ...
- python【第十二篇下】操作MySQL数据库以及ORM之 sqlalchemy
内容一览: 1.Python操作MySQL数据库 2.ORM sqlalchemy学习 1.Python操作MySQL数据库 2. ORM sqlachemy 2.1 ORM简介 对象关系映射(英语: ...
- PHP操作MySQL数据库的相关函数
首先,要分清SQL语句的类型: SQL语句的分类 (1)DDL:Data Define Language,数据定义语言--定义表的列结构 CREATE.DROP.ALTER.TRUNCATE (2)D ...
- Golang原生sql操作Mysql数据库增删改查
Golang要操作mysql数据库,首先需要在当期系统配置GOPATH,因为需要使用go get命令把驱动包下载到GOPATH下使用. 首先配置好你的GOPATH,执行以下命令,下载安装mysql驱动 ...
- 一、初识MySQL数据库 二、搭建MySQL数据库(重点) 三、使用MySQL数据库 四、认识MySQL数据库的数据类型 五、操作MySQL数据库的数据(重点)
一.初识MySQL数据库 ###<1>数据库概述 1. 数据库 长期存储在计算机内的,由组织的可共享的数据集合 存储数据的仓库 文件 ...
- python接口自动化(三十八)-python操作mysql数据库(详解)
简介 现在的招聘要求对QA人员的要求越来越高,测试的一些基础知识就不必说了,来说测试知识以外的,会不会一门或者多门开发与语言,能不能读懂代码,会不会Linux,会不会搭建测试系统,会不会常用的数据库, ...
随机推荐
- numpy.trace对于三维以上array的解析
numpy.trace是求shape的对角线上的元素的和,具体看 https://docs.scipy.org/doc/numpy-1.13.0/reference/generated/numpy.t ...
- grid - 隐式网格
当网格项目确认在显式网格之外时就会创建隐性网格,当没有足够的空间或者显式的网格轨道来设置网格项目,此时网格项目就会自动创建隐式网格. 隐式网格可以定义:grid-auto-rows.grid-auto ...
- 使用Azure的GPU系列虚拟机Ubuntu-16.0.4安装GPU驱动并使用Tensorflow-GPU的过程。
1.source activate python362.source activate tensorflow-gpu3.pip install tensorflow-gpu(提示安装的这个版本:ten ...
- markdownpad目录格式配置
表格语法 | Tables | Are | Cool | | ------------- |:-------------:| -----:| | col 3 is | right-aligned | ...
- IDC机房机器日志采集配置
以机器 gpu-server-011 为例: 机房机器添加AliUids操作 [root@gpu-server-011 ~]# mkdir -p /etc/ilogtail/users/ [root ...
- 如何保证修改resolv.conf后重启不恢复?
如何保证修改resolv.conf后重启不恢复? 修改/etc/resolv.conf,重启网卡后,/etc/resolv.conf恢复到原来的状态. CentOS.redhat下面直接修改/etc/ ...
- [k8s]Docker 用户使用 kubectl 命令指南-unkown排错(kubelet端口解析)
参考:https://kubernetes.io/docs/user-guide/kubectl-cheatsheet/ https://k8smeetup.github.io/docs/user-g ...
- VBA二次学习笔记(3)——批量合并单元格
说明(2018-9-16 22:17:49): 1. 昨天运动会,100米八个人跑了第五,400米五个人跑了第三,得了个榨汁机.终于结束了哈哈哈!之前一个星期紧张的天天拉肚子,真是没出息..不过养成了 ...
- 第四百一十二节,python接口,抽象方法抽象类
Python接口 在Python中所谓的接口,有两种,一种是通过url访问的api接口 一种是一个对象的接口 构造接口 class Ijiekou: """ 定义一个约束 ...
- ScheduledThreadPoolExecutor实现原理
ScheduledThreadPoolExecutor实现原理 博客分类: concurrency java 自jdk1.5开始,Java开始提供ScheduledThreadPoolExecut ...