函数原形: MYSQL_RES *mysql_use_result(MYSQL *mysql);
函数传入值: MYSQL:类型的指针
函数返回值: 一个MYSQL_RES结果结构,如果发生一个错误发NULL
#incluee <mysql/mysql.h>
检索一个结果集合的下一行
MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);
MYSQL_RES:结构的指针
下一行的一个MYSQL_ROW结构 。如果没有更多的行可检索或如果出现一个错误,NULL
#include <mysql/mysql.h>
返回指定结果集中列的数量
unsigned int mysql_num_fields(MYSQL_RES *res);
MYSQL_RES 结构的指针
结果集合中字段数量的一个无符号整数
#include <mysql/mysql.h>
创建一个数据库
int mysql_create_db(MYSQL *mysql,const char *db);
MYSQL:类型的指针
db:要创建的数据库名
如果数据库成功地被创建,返回零,如果发生错误,为非零 。
#include <mysql/mysql.h>
选择一个数据库
int mysql_select_db(MYSQL *mysql,const char *db);
MYSQL:类型的指针
db:要创建的数据库名
如果数据库成功地被创建,返回零,如果发生错误,为非零 。
这里的大部分代码参考了MySQL发行包里面的.c源文件,大家也可以去里面找找相关的代码,下面这段代码实现了连接到本地MySQL服务器上9tmd_bbs_utf8数据库,从数据表tbb_user中根据输入的userid取得该用户的用户名并打印输出到终端 。
#if defined(_WIN32) || defined(_WIN64) //为了支持windows平台上的编译#include <windows.h>#endif#include <stdio.h>#include <stdlib.h>#include "mysql.h" //我的机器上该文件在/usr/local/include/mysql下//定义数据库操作的宏,也可以不定义留着后面直接写进代码#define SELECT_QUERY "select username from tbb_user where userid = %d"int main(int argc, char **argv) //char **argv 相当于 char *argv[]{ MYSQL mysql,*sock; //定义数据库连接的句柄,它被用于几乎所有的MySQL函数 MYSQL_RES *res; //查询结果集,结构类型 MYSQL_FIELD *fd ; //包含字段信息的结构 MYSQL_ROW row ; //存放一行查询结果的字符串数组 char qbuf[160]; //存放查询sql语句字符串 if (argc != 2) { //检查输入参数 fprintf(stderr,"usage : mysql_select <userid>nn"); exit(1); } mysql_init(&mysql); if (!(sock = mysql_real_connect(&mysql,"localhost","dbuser","dbpwd","9tmd_bbs_utf8",0,NULL,0))) { fprintf(stderr,"Couldn't connect to engine!n%snn",mysql_error(&mysql)); perror(""); exit(1); } sprintf(qbuf,SELECT_QUERY,atoi(argv[1])); if(mysql_query(sock,qbuf)) { fprintf(stderr,"Query failed (%s)n",mysql_error(sock)); exit(1); } if (!(res=mysql_store_result(sock))) { fprintf(stderr,"Couldn't get result from %sn", mysql_error(sock)); exit(1); } printf("number of fields returned: %dn",mysql_num_fields(res)); while (row = mysql_fetch_row(res)) { printf("Ther userid #%d 's username is: %sn", atoi(argv[1]),(((row[0]==NULL)&&(!strlen(row[0]))) ? "NULL" : row[0])) ;puts( "query ok !n" ) ;}mysql_free_result(res); mysql_close(sock); exit(0); return 0; //. 为了兼容大部分的编译器加入此行}编译的时候,使用下面的命令
gcc -o mysql_select ./mysql_select.c -I/usr/local/include/mysql -L/usr/local/lib/mysql -lmysqlclient (-lz) (-lm) 后面两个选项可选,根据您的环境情况
运行的时候,执行下面的命令
./mysql_select 1
将返回如下结果:
number of fields returned: 1
Ther userid #1 ‘s username is: Michael
query ok !
【C语言如何操作MySQL数据库?】上面的代码我想大部分都能看明白,不明白的可以参考本博客mysql数据库其他文章,有关C语言API各个函数都有详细说明
推荐阅读
- 如何确定JavaScript中this的指向?这里有5中常见的分类
- 淘宝直播对店铺的影响 淘宝直播的一般违规如何处理
- 如何分辨滇红与古树红茶
- 如何辨别传统滇红与古树红茶的区别
- 从四川到世界,竹叶青峨眉高山绿茶如何铸就问鼎中国十年之路?
- “茶界茅台”竹叶青峨眉高山绿茶如何做到连续十年高端销量领先
- 天猫小黑盒的产品应该怎么操作 天猫小黑盒准入条件
- 如何鉴别红茶的品质 质好的红茶外形纤细紧直
- 都说古树红茶好 如何辨别是否真正的古树红茶
- 这四个方法教你如何辨别红茶品质