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

vs2008下MFC中采用ado连接MySQL(ODBC、非ODBC或C API方式)

2018年07月09日 ⁄ 综合 ⁄ 共 4291字 ⁄ 字号 评论关闭

其实,以前弄过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.2w
Driver;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下载,貌似百度文库方便点

秒速赛车公式 www.l19l7.cn VS编译,提示找不到#include<mysql.h>

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

? 一、通过MyODBC界面??
? 二、通过Connector/C++l界面 ??
? 三、通过MySQL CAPI界面??
? 四、第三方封装的MySQL类 ??
? ??
? 在经过反复比较,我还是选择了MySQLC API方式来进行MySQL的开发。 ??
? 在VC中使用MySQL的步骤如下: ??
? ??
? 1、下载MySQL的服务器/客户端安装包 ??
? 官方下载地址如下:??
? //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》 ??//blog.csdn.net/luxiaoshuai/article/details/5644745

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

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

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

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

?

转自://blog.csdn.net/xuyuefei1988/article/details/8892351

抱歉!评论已关闭.

  • 倒着走能治腰颈椎痛?假的! 2019-04-19
  • 长效机制加速推进 楼市下半年或持续降温 2019-04-19
  • 树立文化自信 创新节庆模式 2019-04-19
  • 朝韩将军级会谈时隔11年后在板门店重启 2019-04-19
  • 经济日报多媒体数字报刊 2019-04-18
  • 搞好公有制就是好,故得出结论:计划经济好。 2019-04-18
  • 云南理发店老板涉嫌杀害女演员因办卡纠纷起杀心 2019-04-18
  • 南海网-海南新闻网-权威媒体 海南门户 2019-04-17
  • 海底捞回应侵犯音乐人林海著作权:已停止播放 2019-04-17
  • 自然型社会和规则性社会,是会随着科技的改变而发生改变的,当然只有规矩也就是制度才能规范人的行为,所以国家是不会灭亡的,但国家的形式是会发生改变的。 2019-04-17
  • 惊艳!上外学子英译60首热门中文歌  让世界倾听中国 2019-04-16
  • 西安,给盲人朋友留一条路吧…无障碍设施盲道-编辑整合 2019-04-16
  • 的确如此。报刊亭取消的确是短视行为。把报刊亭设计的现代化一些,与城市绿化衔接起来,相得益彰,成为文化一景多好。 2019-04-16
  • 让更多企业和劳动者尝到协商的“甜头” 2019-04-16
  • 2014金家岭财富论坛嘉宾云集(二) 2019-04-15
  • 446| 483| 337| 194| 397| 144| 483| 565| 128| 630|