Windows下使用VS的ADO访问MySQL
数据库的访问的一种方式就是:CS结构。即使用TCP/UDP协议进行远程访问,而数据库对于服务端的软件是本地访问!这种管理方式比较常见。
这里主要叙述Windows访问本地数据库的方法。
需要了解几个概念:
1、ADO是什么。ADO (ActiveX Data Objects,ActiveX数据对象)是Microsoft提出的应用程序接口(API)用以实现访问关系或非关系数据库中的数据。ADO也是Microsoft的组件对象模式(COM)的一部分。其实你可以理解成微软程序访问数据库的一种统一的接口,目的是简化数据库的访问(如果不使用ADO,就只能使用各种数据库自己提供的API函数)。
2、脱离平台的数据库包含哪些部分。SQL Server和数据源。至于SQL Server下载参见:https://dev.mysql.com/downloads/installer/。注意这两个版本都是等价的,听说那个容量小的是一个下载器(我下载的是那个容量大的)。SQL Server就相当于数据资源的底层管理者。
3、数据库驱动器(数据库连接器)。它是基于平台的。基于Windows平台的驱动器下载参见:https://dev.mysql.com/downloads/connector/odbc/。总共是4个,眼花了吧!建议下载MSI Installer。这是整个安装包,一键安装,你懂得!64位,32位都要下载!因为下面需要配置ODBC的(都下载了,肯定有一个能用,我的只能用32位的)。
至此需要的软件均已下载完成。
配置:
1、数据库驱动器直接双击安装即可。MySQL安装(包括数据库服务器)比较麻烦一点。都安装上肯定不会出错(我也是初学者)。主要安装MySQL server和MySQL shell、MySQL workbench。整个安装过程中需要配置主机/服务器名、端口、用户名、密码、数据库名。
主机/服务器名写ip地址或者localhost(本地)。端口默认即可,用户名,自己命名,但要记着!密码随便。数据库名随便写一个,因为在shell中你可以对数据库进行删除等操作。(MySQL已安装过了,不想再安装一遍了)。
2、设置odbc数据源(64,32位)均要设置一遍。建议创建系统DSN(所有用户均可访问,文件DSN可以在电脑上进行复制粘贴,如果编给其他电脑的可以选择文件DSN)。
点击右侧添加,
这两种编码自己查(即使查了也不一定能明白),我选的是第二项。
记住自己设置的DSN(Data Source Name)。其他选项一看就懂。至此DSN创建完成。
细心的也可能注意到了:MySQL for Visual Studio:https://dev.mysql.com/ downloads/windows/visualstudio/。听说那是给ADO.NET开发的,不懂.NET的就不要瞎搞了。我也不懂。
至此接口完成!
下面就能进行测试了,测试代码如下:
#include <Windows.h> #include <iostream> #include <string> using namespace std; #import "C:/Program Files/Common Files/System/ado/msado15.dll" no_namespace rename("EOF","adoEOF")rename("BOF","adoBOF") int main(int argc,char *argv[]) { CoInitialize(NULL); //Connect _ConnectionPtr pConn; pConn.CreateInstance(__uuidof(Connection)); try { HRESULT hr = pConn->Open("DSN=dsn;server=localhost;database=mydb;","user","password",adModeUnknown); } catch (_com_error&e) {
cout<< e.Description()<< endl;
return -;
} //Open _RecordsetPtr pRecord; pRecord.CreateInstance(__uuidof(Recordset)); pRecord->CursorLocation = adUseClient; pRecord->PutActiveConnection(pConn.GetInterfacePtr()); //Read try { pRecord->Open(_bstr_t("select * from mytable"), vtMissing,adOpenDynamic,adLockBatchOptimistic,adCmdText); } catch (_com_error &e) { cout<< e.Description()<<endl; //Table 'mydb.mytable' doesn't exist } while (!pRecord->adoEOF) { _variant_t vID = pRecord->GetCollect(_variant_t((long))); _variant_t vName = pRecord->GetCollect("name"); _variant_t vSex = pRecord->GetCollect("sex"); cout<< (char*)(_bstr_t)vName<< " "; cout<< (char*)(_bstr_t)vSex<< " "<<endl; pRecord->MoveNext(); } //Close pRecord->Close(); pConn->Close(); CoUninitialize(); return ; };
主要是配置pConn->Open()的参数,你的参数不一定跟我一样。如果直接运行的话,pRecord->Open()会抛出一个错误:Table 'mydb.mytable' doesn't exist。就是数据库是空的!
在这里往数据库中添加一些数据:
1. 打开MySQL 5.7 Command Line Client - Unicode(MySQL安装时,安装的),输入密码,回车。
2、输入指令进行添加数据。shell命令参考:http://blog.csdn.net/w174504744/article/details/7884997
3、注意shell命令单词之间的空格!
大家都是初学者,数据库创建完成,我现在还没找到数据库具体放哪呢。
声明:程序是粘贴的别人的!测试好用。如有侵权,请告诉我。
OVER!
Windows下使用VS的ADO访问MySQL的更多相关文章
- 在Windows下安装64位压缩包版mysql 5.7.11版本的方法
为了学习数据库,自己去网上下载了最新版本的Windows64位的mysql 5.7.11,但是花了很长的时间在安装的问题上,同时也借鉴了几位前辈的博文来帮助自己解决在安装过程中遇到的问题,安装成功之后 ...
- 在windows下使用vs2013编译和调试mysql源代码
1. 准备工作 1)OS:win10 + VS2013 2)mysql 源码(windows版):mysql-5.6.25.zip 3)perl tool:ActivePerl-5.16.3.1604 ...
- windows下配置svn的https访问
svn是一个功能强大的代码版本管理系统,可以将服务端安装在linux.unix以及windows下.svn通常采用http方式进行代码提交与下载.由于密码采用明文传输,因此存在泄密的风险.若采用htt ...
- windows下通过VNC图形化访问Ubuntu桌面环境
要在windows下图形化访问Ubuntu或其它Linux系统桌面环境有很多方法,我比较喜欢的是使用VNC服务,需要在Ubuntu下安装vncserver和在windows下安装客户端访问工具. 1. ...
- windows下安装Apache、php、mysql集成环境
一.准备工作 本次安装的版本分别为:apache2.4 .php5.6 . mysql5.7 下载地址为:http://pan.baidu.com/s/1boQNIOn 密码:zarx 二.安装步骤 ...
- Windows下: RubyMine + Ruby On Rails + mysql 搭建开发环境
最近在接手一个手机项目.在搭建环境的过程中,遇到了一些问题,在下文中已做记录,并奉上个人的解决方案. 开发环境 win2003 ; JetBrains RubyMine6.3.3 1. 下载最新版 ...
- windows 下wamp环境2 配置之mysql的安装
安装配置mysql 5.7 打开mysql官网: https://www.mysql.com/ 点击downloads,然后选择commuity 选择MySQL Community Server选择对 ...
- Windows下如何使用CMD命令进入MySQL数据库
1.打开[开始]>[运行]输入[cmd]单击[确定]后出现CMD命令黑色窗口,这就是我们说的CMD命令行,或者使用快捷键Windows键(在键盘上有个Windows标志的按键)+R输入cmd后回 ...
- windows 下使用 zip安装包安装MySQL 5.7
以下内容参考官方文档:http://dev.mysql.com/doc/refman/5.7/en/windows-start-command-line.html 解压缩zip到D:\mysql-5. ...
随机推荐
- AOJ GRL_1_B: Shortest Path - Single Source Shortest Path (Negative Edges) (Bellman-Frod算法求负圈和单源最短路径)
题目链接: http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=GRL_1_B Single Source Shortest Path ...
- ARM的六大类指令集---LDR、LDRB、LDRH、LDM、STR、STRB、STRH、STM
http://blog.csdn.net/u013477200/article/details/50723555
- Linux 安装软件的几种方式
目录 几种安装方式 源代码编译安装 借助软件包管理器安装 二进制格式安装 总结 参考 几种安装方式 源代码编译安装 源代码包的安装一般为下载软件源代码,然后编译安装.常见的 C 程序软件的安装步骤是 ...
- shell基础编程
首先要注意的是,Ubuntu里的shell的sh和bash命令是有区别的 如下所示,Ubuntu下的sh指向的dash程序,而bash是dash的增强版,一些bash上能执行的程序在dash上不行 如 ...
- exsi中的虚拟机添加磁盘后虚拟机中磁盘不出现
exsi中的虚拟机添加磁盘后虚拟机中磁盘不出现解决: 计算机---> 管理: 这里可以选择磁盘,格式,分区, 改盘符等操作
- 中级前端工程师要掌握的JavaScript 技巧
1.判断对象的数据类型 2.Es5实现数组map方法 3.使用reduce实现数组map方法 4.ES5 实现数组filter方法 5.使用reduce实现filter方法 6.ES5 实现数组som ...
- (2016北京集训十二)【xsy1542】疯狂求导
题解: 这题看起来很难...但是实际上并没有想象中的那么难 第一眼看上去不会求导公式怎么办?不要紧,题目背景非常良心的给出了题目中的导数计算公式 求完导合并同类项很恶心怎么办?不要紧,样例解释说明了不 ...
- bzoj4551 [HEOI2016]树
题目描述 在2016年,佳媛姐姐刚刚学习了树,非常开心.现在他想解决这样一个问题:给定一颗有根树(根为1),有以下 两种操作:1. 标记操作:对某个结点打上标记(在最开始,只有结点1有标记,其他结点均 ...
- POJ-3436 ACM Computer Factory 最大流 为何拆点
题目链接:https://cn.vjudge.net/problem/POJ-3436 题意 懒得翻,找了个题意. 流水线上有N台机器装电脑,电脑有P个部件,每台机器有三个参数,产量,输入规格,输出规 ...
- CodeForces-1007A Reorder the Array 贪心 田忌赛马
题目链接:https://cn.vjudge.net/problem/CodeForces-1007A 题意 给个数组,元素的位置可以任意调换 问调换后的元素比此位置上的原元素大的元素个数最大多少 思 ...