其实,以前弄过sql,mysql应该是顺理成章很简单的事情,但很无奈,傻傻地弄了很久,还请教了别人,别人告诉我的跟我在网上查到的都是一样的,但还是不行,归根接地就是“mysql-connector-odbc-5.2.4-win32”这个odbc这里版本号出了问题。

自己下载的是MySQL-installer-community-5.6.10.1(含odbc5.2.4),装完后发现自带了odbc5.2.4,接下来的操作很自然用了“Driver=MySQL ODBC 5.2 Driver”这里就出问题了,版本号一定要弄清楚,否者肯定要出错,当然很多人自己下的odbc所以根本不会出这个问题,这里只是一个无知者的提醒。出现的ODBC5.1是自己装的,你直接用“Driver=MySQL ODBC 5.1 Driver”自然也是没问题。

一、非ODBC

1.下载mysql数据库.(mysql-5.1.28-rc-win32)

2.下载与mysql数据库版本相同的odbc(mysql-connector-odbc-noinstall-5.1.8-win32),两者版本必须相同,否则会报错。

3.可以下载MySql-Front工具,可视化对MySql操作。

3.打开MFC程序,在stdafx.h中加入一句:

#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","rsEOF")

4.在要打开的cpp程序中加入以下语句,变量也可定义到头文件,adModeUnknown是数据库访问权限常量,我输入别的都不行,就输入这个可以,权限设置还要再学习。

CoInitialize(NULL);

_ConnectionPtr pConn;
_RecordsetPtr pRs("ADODB.Recordset");

pConn.CreateInstance(__uuidof(Connection));
  HRESULT hr=pConn->Open("Driver=MySQL ODBC 5.2wDriver;Server=127.0.0.1;Database=test","root","123456",adModeUnknown);

pRs->Open("Select * From avInfo",_variant_t(pConn,true),adOpenStatic,adLockOptimistic,adCmdText);

CString strID= (LPCTSTR)_bstr_t(pRs->GetCollect("FlightNO"));

二、ODBC

跟非odbc的唯一区别在

m_pConnectionPtr->Open("DSN=FEIFEI;Server=localhost;Database=feifei","root","19880512",adModeUnknown);//成功,当然要配置odbc,data source name =FEIFEI

配置如下:

三、C API方式(自己就没用过了)

一、环境

编译环境: 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

以上转自:http://blog.csdn.NET/sciland/article/details/4274364

另外,MySQL的语法大全也非常值得一看:http://wenku.baidu.com/view/29648f2458fb770bf78a552f.html

MFC连接MySQL的更多相关文章

  1. MFC连接MySQL数据库方法

    MFC连接数据库的三种方法: 1.ODBC(开放式数据互联) 2.OLEDB与ADO 3.用mysql为C语言提供的接口

  2. MFC连接Mysql数据库执行查询和插入

    配置环境: include:mysql.h文件 lib:libmysql.lib文件 dll::libmysql.dll文件 连接代码: MYSQL m_sqlCon; MYSQL_RES *m_re ...

  3. MFC连接MySQL C API方法

    1.首先下载一个32位的MySQL,因为vc的版本是32位了,不用32 位的MySQL会出现无效的机械码错误. MySQL安装地址:https://dev.mysql.com/downloads/my ...

  4. MFC通过ODBC连接Mysql程序

    分享到 一键分享 QQ空间 新浪微博 百度云收藏 人人网 腾讯微博 百度相册 开心网 腾讯朋友 百度贴吧 豆瓣网 搜狐微博 百度新首页 QQ好友 和讯微博 更多... 百度分享 MFC通过ODBC连接 ...

  5. c++连接mysql并提示“无法解析的外部符号 _mysql_server_init@12”解决方法&提示缺少“libmysql.dll”

    课程作业要用c++连接mysql server,但是出现些小问题,经查阅资料已经解决,做一下笔记. 环境:vs2017, mysql版本是8.0.16-winx64. 设置项目属性   项目 -  C ...

  6. MFC通过ODBC连接mysql(使用VS2012编写MFC)

    原创文章,转载请注明原文:MFC通过ODBC连接mysql(使用VS2012编写MFC) By Lucio.Yang 1.ODBC连接mysql 首先ODBC是什么呢? 开放数据库互连(Open Da ...

  7. C++连接mysql的两种方式(ADO连接和mysql api连接)

    一.ADO连接mysql 1.安装mysql-5.5.20-win32.msi和mysql-connector-odbc-5.3.4-win32.msi(一般两个安装程序要匹配,否则可能连接不上)  ...

  8. C++ ADO 连接 mysql

    1.安装mysql-5.0.22-win32,mysql-connector-odbc-5.1.12-win32.msi    然后:开始菜单->设置->控制面板->管理工具-> ...

  9. nodejs进阶(6)—连接MySQL数据库

    1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...

随机推荐

  1. js replaceAll全部替换

    js不支持replaceAll,可以用函数new RegExp('要替换的内容','g')代替, 代码: str.replace(new RegExp('要替换的内容','g'),"替换内容 ...

  2. 开机进入boot menu和application menu,无法开机

        1.开机点击F1进入到bios界面 2.进入Security—Secure Boot—Disabled 如果不修改Secure boot选项为Disabled,在光驱引导时可能会出现报错 3. ...

  3. [leetcode]678. Valid Parenthesis String验证有效括号字符串

    Given a string containing only three types of characters: '(', ')' and '*', write a function to chec ...

  4. Python 安装pyautogui

    在Python中使用PyAutoGui模拟键盘和鼠标操作 一.系统环境 操作系统:win10 64位 Python版本:Python 3.7.0 二.安装参考 1.使用pip进行安装,pip inst ...

  5. 举个通俗易懂的例子告诉你IAAS,SAAS,PAAS的区别

    作者:何足道链接:https://www.zhihu.com/question/21641778/answer/62523535来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  6. HashMap从源码分析数据结构

    1. HashMap在链表中存储的是键值对 2. 数组是一块连续的固定长度的内存空间,再好的哈希函数也不能保证得到的存储地址绝对不发生冲突.那么哈希冲突如何解决呢?哈希冲突的解决方案有多种:开放定址法 ...

  7. avalon 双向绑定在新版chrome中不能同步中文输入

    1>1.x和2.x都有这样的问题,输入中文无法同步到VM,演示地址 http://codepen.io/roscoe054/pen/XXKYMj?editors=1111 chrome 版本 5 ...

  8. 微信小程序解密

    获取OpenId和SessionKey private string GetOpenIdAndSessionKeyString(string code) { string wxUrl = " ...

  9. mybatis入门--初识mybatis

    初识mybatis 今天,一起来说说mybits这个框架吧.这是一个持久层的框架.之前叫做ibatis.所以,在它的代码中出现ibatis这个词的时候,不要感到惊讶.不是写错了,它确实就是这个样子的. ...

  10. [转载]RPM中SPEC常用路径以及宏变量

    转自:http://blog.csdn.net/txgc1009/article/details/6833764 通过命令rpm --showrc查看实现代码.另外直接通过 rpm --eval &q ...