如何编程连接mysql_怎样用c/c++编程连接mysql数据库?

http://www.mysql.com/doc/en/C.html

[转贴自http://homepage.qdcatv.com.cn/antonio/mysql/mysql.htm]

执行一个查询有以下几个步骤要做。首先执行一个查询,然后保存结果,

得到的是一个子集。这里是一个小例子:

#include

#include

#include   "mysql.h"

MYSQL   mysql;

MYSQL_RES   *res;

MYSQL_ROW   row;

void   exiterr(int   exitcode)

{

fprintf(   stderr,   "%s\n",   mysql_error(&mysql)   );

exit(   exitcode   );

}

int   main()

{

uint   i   =   0;

if   (!(mysql_connect(&mysql,"host","username","password")))

exiterr(1);

if   (mysql_select_db(&mysql,"payroll"))

exiterr(2);

if   (mysql_query(&mysql,"SELECT   name,rate   FROM   emp_master"))

exiterr(3);

if   (!(res   =   mysql_store_result(&mysql)))

exiterr(4);

while((row   =   mysql_fetch_row(res)))   {

for   (i=0   ;   i   <   mysql_num_fields(res);   i++)

printf("%s\n",row[i]);

}

mysql_free_result(res);

mysql_close(&mysql);

}

mysql_query   函数将把查询送给服务器,如果查询成功,调用mysql_store_result

函数将分配一个MYSQL_RES   结构并且重新从服务器获得一个结果集。你可以用

mysql_fetch_row   函数来查看数据。这样做你将获得一个   MYSQL_ROW   指针指向数

据中的一行。   MYSQL_ROW   指针是一简单的字符串数组。所有的数据类型被转换成

字符串送到客户端。

mysql_num_fields   函数将告诉你返回的列数。你可以继续调用   mysql_fetch_row

直到它返回一个空指针以得到查询中的每一行。

注意在这个例子里,我们没有检查有空指针的列。如果你不使用非空列的表,那么

你必须检查一个特殊行的列是否为空。

一旦你使用完毕一个结果集,你必须释放它。这通过   mysql_free_result   来完成。

最后调用   mysql_close   来关闭你和数据库之间的连接。

查看结果集

你可以不用调用   mysql_fetch_row   就查出返回的结果集共有多少行。这由

int   mysql_num_rows(MYSQL_RES   *result)来完成。

改变到被下一个   mysql_fetch_row   调用返回的行,你可以用

void   mysql_data_seek(MYSQL_RES   *res,   uint   offset)   改变到任意一行。

获得更多的信息

你可以使用这几个额外的函数来找出关于一个查询的更多的信息,并从服务器获得

这些信息。

如果你执行一个UPDATE,   INSERT   或者   DELETE   查询,你可以用

int   mysql_affected_rows   来查出共有多少行数据被你影响到。

如果在你的数据库里有二进制数据,那么得知数据的长度将是有用的。unsigned

int   *mysql_fetch_lengths(MYSQL_RES   *mysql)   将返回一指出了结果集中每一列

的长度的整型数组。

当你插入一个带有   AUTO_INCREMENT   列的表的时候,你可以用

int   mysql_insert_id(MYSQL   *mysql)   来查出生成的那一行的ID。

======================

我连过成功了!

#include   "/include/mysql/mysql.h"   /*为绝对路径*/

#include  

int   main(int   argc,char   *argv[])

{

char   *user   =   "root",   *pwd   =   "mysql",   *dbname   =   "mysql";

MYSQL   mysql;

MYSQL_RES   *mysql_ret;

MYSQL_ROW   mysql_row;

unsigned   long   num_rows;

int   ret;

mysql_init(&mysql);

if(mysql_real_connect(&mysql,NULL,user,pwd,dbname,0,NULL,0))

{

printf("Connection   success!\n");

ret   =   mysql_query(&mysql,"select   *   from   user");

if(!ret)

{

printf("Query   Success!\n");

mysql_ret   =   mysql_store_result(&mysql);

if(mysql_ret   !=   NULL)

{

printf("Store   Result   Success!\n");

num_rows   =   mysql_num_rows(mysql_ret);

if(num_rows   !=   0)

{

printf("%d\n",num_rows);

while(mysql_row   =   mysql_fetch_row(mysql_ret))

{

printf("%s\t%s\t%s\t%s\t%s\t%s\n",mysql_row[0],mysql_row[1],mysql_row[2],mysql_row[3],mysql_row[4],mysql_row[5]);

}

}

else

{

printf("mysql_num_rows   Failed!\n");

exit(-1);

}

mysql_free_result(mysql_ret);

exit(0);

}

else

{

printf("Store   Result   Failed!\n");

exit(-1);

}

}

else

{

printf("Query   Failed!\n");

exit(-1);

}

}

else

{

printf("Connection   Failed\n");

exit(-1);

}

}

如果你包含了正确的头文件而在连接的时候,   告诉你没有符号连接

你应该连接你需要的库

我的/lib/mysql/libmysqlclient.so下面

gcc   -L/lib/mysql   -lmysqlclient   -o   tes   tes.c   进行编译

RedHat_shu@hotmail.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值