mysql的使用

来源:互联网 发布:sklearn 知乎 编辑:程序博客网 时间:2024/06/13 13:17

 [转贴自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   <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   进行编译   
    
    
附mysql的windows安装以及函数说明:

通过VC开发MySQL数据库应用软件有多种方式: 
一、通过MyODBC界面 
二、通过Connector/C++l界面 
三、通过MySQL C API界面 
四、第三方封装的MySQL类 

在经过反复比较,我还是选择了MySQL C API方式来进行MySQL的开发。 
在VC中使用MySQL的步骤如下: 

1、下载MySQL的服务器/客户端安装包 
官方下载地址如下: 
http://www.mysql.com/downloads/mysql-4.0.html 
由于我的开发环境是Windows,所以我下载的是MySQL for Windows V4.0.12 

2、安装MySQL服务器/客户端包 
一般情况,选择下一步就行了。 
默认情况,MySQL会安装到C:/mysql下。 

3、在VC中设置其开发环境 
[选项/项目/VC目录] 
a.设置包含路径为c:/mysql/include 
b.设置引用路径为c:/mysql/include 
c.设置库路径为c:/mysql/lib/debug 
[项目属性] 
d.在设置链接器-输入-附加依赖项为libmySQL.lib 
e.在stdafx.h中加入以下行: 
#include <winsock.h> 
#include "mysql.h" 

4、至此就可以使用C API函数进行开发了。 

FAQ: 
1.若出现无法使用mysql.h定义的类型的错误时,可重新生成工程即可. 

2.若出现链接错误,可将libmySQL.dll文件拷贝到工程当前目录下. 

MySQL提供了很多函数来对数据库进行操作,大致可以分为以下几类: 

第一部分 控制类函数 

mysql_init()初始化MySQL对象 
mysql_options()设置连接选项 
mysql_real_connect()连接到MySQL数据库 

mysql_real_escape_string()将查询串合法化 
mysql_query()发出一个以空字符结束的查询串 
mysql_real_query()发出一个查询串 

mysql_store_result()一次性传送结果 
mysql_use_result()逐行传送结果 

mysql_free_result()释放结果集 

mysql_change_user()改变用户 
mysql_select_db()改变默认数据库 

mysql_debug()送出调试信息 
mysql_dump_debug_info()转储调试信息 

mysql_ping()测试数据库是否处于活动状态 
mysql_shutdown()请求数据库SHUTDOWN 

mysql_close()关闭数据库连接 

第二部分 信息获取类函数 
mysql_character_set_name()获取默认字符集 
mysql_get_client_info()获取客户端信息 
mysql_host_info()获取主机信息 
mysql_get_proto_info()获取协议信息 
mysql_get_server_info()获取服务器信息 
mysql_info()获取部分查询语句的附加信息 
mysql_stat()获取数据库状态 

mysql_list_dbs()获取数据库列表 
mysql_list_tables()获取数据表列表 
mysql_list_fields()获取字段列表 

第三部分 行列类操作函数 
mysql_field_count()获取字段数 
mysql_affected_rows()获取受影响的行数 
mysql_insert_id()获取AUTO_INCREMENT列的ID值 

mysql_num_fields()获取结果集中的字段数 
mysql_field_tell()获取当前字段位置 
mysql_field_seek()定位字段 
mysql_fetch_field()获取当前字段 
mysql_fetch_field_direct()获取指定字段 
mysql_frtch_fields()获取所有字段的数组 



mysql_num_rows()获取行数 
mysql_fetch_lengths()获取行长度 
mysql_row_tell()获取当前行位置 
mysql_row_seek()行定位 
mysql_data_seek()行定位 
mysql_fetch_row()获取当前行 


第四部分 线程类操作函数 
mysql_list_processes()返回所有线程列表 
mysql_thread_id()获取当前线程ID 
mysql_thread_safe()是否支持线程方式 
mysql_kill()杀列一个线程 


第五部分 出错处理类函数 
mysql_errno()获取错误号 
mysql_error()获取错误信息 

第六部分 已过时的函数 
mysql_connect() 
mysql_create_db() 
mysql_drop_db() 
mysql_eof() 
mysql_reload() 
mysql_escape_string()