vc6.0 通过ADO(udl)连接sql 2008
转载声明:本文转自http://blog.sina.com.cn/s/blog_7328b9dd0100pkbw.html茗之的博客
首先声明:本文是针对vc与sql菜鸟的,高人请让路。
本文讲解了用ADO技术连接VC6.0与sql2008(sql2000也一样)。
1.首先在vc6.0中新建一个基于对话框的应用程序,其他选项均为默认。本例中名称为Rent。(如果有问题请看vc教程)
2.在Rent项目的文件夹里建立一个udl文件。
步骤:(1)新建一个txt文件。
(2)把后缀名改为udl,并重命名。本例中用my_data1.udl
(3)双击m_data1.udl设置连接属性,如下图。
其中服务器输入本地的sql服务器即可。数据库选择要连接的数据库。
配置好后可以点“测试连接”按钮来测试是否连接成功。
3.配置好了udl文件后就可以在vc中来连接数据库了。
具体步骤:(1)引入ADO动态链接库。方法如下:在Rent工程的StdAfx.h头文件中添加如下代码:
#import"c:\program files\common files\system\ado\msado15.dll" no_namespace rename ("EOF","adoEOF")
此处有2点要注意:1):此代码必须在一行里面。
2):不能添加到头文件的第一行,不然会报错。(笔者添加到了最后一行)
(2)初始化COM库环境。(因为ADO是基于COM库的,所以要初始化COM库环境)
1):在CRentapp的成员函数InitInstance()中添加如下代码:
::CoInitialize(NULL);//初始化COM库
2):在CRentapp中添加虚函数ExitInstance(),在其中添加如下代码:
::CoUninitialize();//清除COM库
(3)建立连接:
1):在CRentDlg类中添加一个_ConnectionPtr接口类型的成员变量
protected:
_ConnectionPtr m_pConnection;
2):在CRentDlg类的OnInitDialog()函数中添加如下代码:
HRESULT hr;
try
{
hr=m_pConnection.CreateInstance(__uuidof(Connection));
if(SUCCEEDED(hr))
{
m_pConnection->ConnectionString="File Name=my_data1.udl";
m_pConnection->ConnectionTimeout=10;
hr = m_pConnection->Open("","","",adConnectUnspecified);
AfxMessageBox("open succceeded!");
if(FAILED(hr))
{
AfxMessageBox("open fail!");
return true;
}
}
else
{
AfxMessageBox("createinstance of Connection fail!");
return true;
}
}
catch(_com_error e)
{
_bstr_t bstrSource (e.Source());
_bstr_t bstrDescription(e.Description());
AfxMessageBox(bstrSource + bstrDescription);
return true;
}
此处有1点需注意:"File Name=my_data1.udl";此句my_data1.udl前面不能有空格,因为书写习惯,有的人会在其前面加上空格,这样会报错。
4.做完了这些,然后编译,执行,就可以连接上数据库了。
个人认为连接数据库比较重要,因为连都连不上还谈何操作,至于后面的对数据库的操作即是添加相应的消息处理代码而已。连接步骤虽然简单,但对于初学者来说还是容易出问题,在此写个个人的连接心得,也算帮助初学者吧。
vc6.0 通过ADO(udl)连接sql 2008的更多相关文章
- vc6.0 使用Ado 连接MS-SqlServer2000 连接字符串
vc6.0 使用Ado 连接MS-SqlServer2000 连接字符串 分类: C/C++ VC 2012-04-12 20:23 836人阅读 评论(0) 收藏 举报 sql server数据库服 ...
- JDBC连接SQL server与ADO.NET连接Sql Server对比
JDBC连接SQL server与ADO.NET连接Sql Server对比 1.JDBC连接SQL server 1)java方面目前有很多驱动能够驱动连接SQL servernet. 主流的有 ...
- [转载]C#中使用ADO.NET连接SQL Server数据库,自动增长字段用作主键,处理事务时的基本方法
问题描述: 假设在数据库中存在以下两张数据表: User表,存放用户的基本信息,基本结构如下所示: 类型 说明 ID_User int 自动增长字段,用作该表的主键 UserName varcha ...
- Java 如何连接 SQL 2008 R2
前提: 1. 复制sqljdbc_auth.dll到C:\Windows\System32这个路径下. 2. 添加sqljdbc4.jar到Libraries里面. 代码示例: import java ...
- C++中用ODBC和ADO方式连接SQL数据库
https://wenku.baidu.com/view/f01e4e762f3f5727a5e9856a561252d380eb2033.html
- 【转】PowerShell 连接SQL Server 数据库 - ADO.NET
转至:http://www.pstips.net/connect-sql-database.html PowerShell 通过ADO.NET连接SQL Server数据库,并执行SQL脚本.工作中整 ...
- SQL 2008无法连接的解决办法
问题: 在从本地客户端连接到SQL 2008的时候出现无法连接的错误.错误信息如下所示:
- SSMS 2005 连接 SQL SERVER 2008问题
用本机的 Microsoft SQL Server Management Studio 2005 客户端连接数据库服务器时报错:"This version of Microsoft SQL ...
- 连接SQL SERVER 2008需要加端口号
VC2010 ADO 连接SQL SERVER 2008,127.0.0.1,1433,要加上端口,否则连不上.注意:地址和端口之间使用逗号隔开. 连接SQL SERVER 2000可以不加端口号,使 ...
随机推荐
- 批量迁移Oracle数据文件,日志文件及控制文件
有些时候需要将Oracle的多个数据文件以及日志文件重定位或者迁移到新的分区或新的位置,比如磁盘空间不足,或因为特殊需求.对于这种情形可以采取批量迁移的方式将多个数据文件或者日志文件实现一次性迁移.当 ...
- mysql的password()函数和md5函数
password用于修改mysql的用户密码,如果是应用与web程序建议使用md5()函数, password函数旧版16位,新版41位,可用select length(password('12345 ...
- DataReader方式 获取数据的操作
一.使用DataReader读取为对象List /// <summary> /// 获得数据列表List<>,DataReader 使用参数的 /// </summary ...
- bjfu1281
思路挺简单的,但因为需要处理大数,所以就比较耗代码了. /* * Author : ben */ #include <cstdio> #include <cstdlib> #i ...
- VM虚拟机快照还原效果实现方式
===================================================默认"快照删除"行为:============================ ...
- stitch image app (Qt)
result how to use? source code http://7qnct6.com1.z0.glb.clouddn.com/dropSelect.rar
- 《VC++ 6简明教程》即VC++ 6.0入门精讲 学习进度及笔记
VC++6.0入门→精讲 2013.06.09,目前,每一章的“自测题”和“小结”三个板块还没有看(备注:第一章的“实验”已经看完). 2013.06.16 第三章的“实验”.“自测题”.“小结”和“ ...
- ansible文件模块使用
1. 文件组装模块-assemble assemble主要是将多份配置文件组装为一份配置文件. 参数 必填 默认 选项 说明 Backup 否 No Yes/no 是否创建备份文件,使用时间戳 Del ...
- nagios高可用性设置
1. 前言 如何来实现nagios监控系统的高可用,监控是很重要的,在关键时刻进行通知报警,通知人员进行相应的处理. 在进行配置的时候,需要配置两台相同服务的nagios服务器,配置相同,同时在运行, ...
- (转)MFC消息机制
转自:http://blog.csdn.net/kongfuxionghao/article/details/35882533