现在的位置: 首页 > 综合 > 正文

MFC积累—20111123 MFC与MySql的链接 VS2008

2012年03月17日 ⁄ 综合 ⁄ 共 2809字 ⁄ 字号 评论关闭

一、环境

编译环境: VS2008

MySql版本:mysql-5.5.18-win32.msi  

下载地址:点击打开链接 

MYSQL官网,选择的是MySQL Community Server 

 

二、安装连接

安装步骤:资料来源百度文库或者CSDN下载,貌似百度文库方便点

VS编译,提示找不到#include<mysql.h>

通过VC开发MySQL数据库应用软件有多种方式:   

  一、通过MyODBC界面  
  二、通过Connector/C++l界面   
  三、通过MySQL CAPI界面  
  四、第三方封装的MySQL类   
    
  在经过反复比较,我还是选择了MySQLC 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  

 a、b、c均不可少
  [项目属性]  
  d.在设置链接器-输入-附加依赖项为libmySQL.lib   

  在stdafx.h中加入以下行:   
  #include <winsock.h>   
  #include "mysql.h"   

 或者不需要设置链接器,可在stdxfx.h需多添加一行,等同效果

#pragmacomment(lib,"libmysql.lib")    

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

 

 FAQ:   
  1.若出现无法使用mysql.h定义的类型的错误时,可重新生成工程即可.      
  2.若出现链接错误,可将libmySQL.dll文件拷贝到工程当前目录下.   

 

三、Mysql API函数

  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()   

 收集相关文章地址:

1、《vs2008下c++链接mysql》   http://blog.csdn.net/luxiaoshuai/article/details/5644745

2、《vc但文件连接mysql实例,丢掉libmysql.dll》 http://blog.csdn.net/zwfgdlc/article/details/5556654

3、   vs2008连接MySQL,采用C
API方式
http://blog.csdn.net/sciland/article/details/4274364

抱歉!评论已关闭.