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

楼主gaohengwei() 2002-11-15 15:59:42 在 Linux/Unix社区 / 程序开发区 提问

用c/c++连mysql数据库一般用哪些方法,有没有类似vc用的mysql++类库,或者delphi开发常用的mysql控件什么的?在哪里能找到些这方面的资料? 问题点数:20、回复次数:4Top

scrolling="no" frameborder="0" src="http://topic.csdn.net/Include/Board.htm?Tags=c/c++,mysql,null,t%s,exiterr,rows,ret,printf,num,res">

1 楼CDSoftwareWj(95927)回复于 2002-11-15 16:04:10 得分 0

你可以试试Kylix的dbExpress   ^^Top

2 楼x86(大雪)回复于 2002-11-15 18:24:30 得分 10

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。  
   
  Top

3 楼RedHatshu(我还小)回复于 2002-11-15 19:20:16 得分 10

我连过成功了!  
   
  #include   "/include/mysql/mysql.h"   /*为绝对路径*/    
  #include   <stdio.h>    
   
  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

【来源】
Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐