MFC连接MySQL
其实,以前弄过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的更多相关文章
- MFC连接MySQL数据库方法
MFC连接数据库的三种方法: 1.ODBC(开放式数据互联) 2.OLEDB与ADO 3.用mysql为C语言提供的接口
- MFC连接Mysql数据库执行查询和插入
配置环境: include:mysql.h文件 lib:libmysql.lib文件 dll::libmysql.dll文件 连接代码: MYSQL m_sqlCon; MYSQL_RES *m_re ...
- MFC连接MySQL C API方法
1.首先下载一个32位的MySQL,因为vc的版本是32位了,不用32 位的MySQL会出现无效的机械码错误. MySQL安装地址:https://dev.mysql.com/downloads/my ...
- MFC通过ODBC连接Mysql程序
分享到 一键分享 QQ空间 新浪微博 百度云收藏 人人网 腾讯微博 百度相册 开心网 腾讯朋友 百度贴吧 豆瓣网 搜狐微博 百度新首页 QQ好友 和讯微博 更多... 百度分享 MFC通过ODBC连接 ...
- c++连接mysql并提示“无法解析的外部符号 _mysql_server_init@12”解决方法&提示缺少“libmysql.dll”
课程作业要用c++连接mysql server,但是出现些小问题,经查阅资料已经解决,做一下笔记. 环境:vs2017, mysql版本是8.0.16-winx64. 设置项目属性 项目 - C ...
- MFC通过ODBC连接mysql(使用VS2012编写MFC)
原创文章,转载请注明原文:MFC通过ODBC连接mysql(使用VS2012编写MFC) By Lucio.Yang 1.ODBC连接mysql 首先ODBC是什么呢? 开放数据库互连(Open Da ...
- C++连接mysql的两种方式(ADO连接和mysql api连接)
一.ADO连接mysql 1.安装mysql-5.5.20-win32.msi和mysql-connector-odbc-5.3.4-win32.msi(一般两个安装程序要匹配,否则可能连接不上) ...
- C++ ADO 连接 mysql
1.安装mysql-5.0.22-win32,mysql-connector-odbc-5.1.12-win32.msi 然后:开始菜单->设置->控制面板->管理工具-> ...
- nodejs进阶(6)—连接MySQL数据库
1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...
随机推荐
- TZOJ 3710 修路问题(最小差值生成树kruskal或者LCT)
描述 xxx国“山头乡”有n个村子,政府准备修建乡村公路,由于地形复杂,有些乡村之间可能无法修筑公路,因此政府经过仔细的考察,终于得到了所有可能的修路费用数据.并将其公布于众,广泛征求村民的修路意见. ...
- Netty---入门程序,搭建Websocket 服务器
Netty 常用的场景: 1.充当HTTP 服务器,但Netty 并没有遵循servlet 的标准,反而实现了自己的一套标准进行Http 服务: 2,RPC 远程调用,在分布式系统中常用的框架 3.S ...
- linux命令学习之:touch
touch命令有两个功能:一是用于把已存在文件的时间标签更新为系统当前的时间(默认方式),它们的数据将原封不动地保留下来:二是用来创建新的空文件. 语法 touch(选项)(参数) 选项 -a:或-- ...
- mysql事务四大特性
本篇讲诉数据库中事务的四大特性(ACID)和简单操作 ⑴ 原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,这和前面两篇博客介绍事务的功能是一样的概念,因此事务 ...
- 血的教训:Protocol http not supported or disabled in libcurl
报错显示:http not supported or disabled in libcurl 查看配置 curl -V ---------------------------------------- ...
- Cmd下修改文件访问控制权限
保证自己的磁盘分区格式是NTFS.FAT32是不行的. 一.Cacls.exe命令的使用 这是一个在Windows 2000/XP/Server 2003操作系统下都可以使用的命令,作用是显示或者修改 ...
- Vue 全局注册逐渐 和 局部注册组件
//定义一个名为 button-counter 的新组件 Script: Vue.component('button-counter',{//button-counter 这个是组件的名字 data: ...
- mybatis进阶--输入映射和输出映射
我们知道,mapper.xml是我们配置操作数据库的sql语句的地方.其中每个sql语句对应着一个方法,每个方法都有自己的输入输出参数类型.那么这些类型都是怎么配置的呢?今天我们来一起学习下. 输入映 ...
- 利用spring boot构建一个简单的web工程
1.选择Spring InitiaLizr, jdk选择好路径 2.设置项目信息 3.这一步是设置选择使用哪些组件,这里我们只需要选择web 4.设置工程名和路径
- C++树的插入和遍历(关于指针的指针,指针的引用的思考)
题目 写一个树的插入和遍历的算法,插入时按照单词的字典顺序排序(左边放比它"小"的单词,右边放比它"大"的单词),对重复插入的单词进行计数. 程序源码 #inc ...