服务器 频道

VC++ Oracle 开发入门教程

  【IT168 服务器学院】ORACLE 数据库以其优良的性能得到广泛的称赞。但是 ORACLE 客户端不像 SQL Server 能方便地连接到数据库。首先,要给客户机装一个 ORACLEL OLEDB 通讯软件,该软件可从如下地址获得:

 ftp://yblshenzhen.8800.org/OraOLEDB.exe

 www.oracle.com

 只有安装了此软件,客户机才可以和 ORACLE 服务器通讯。为什么 SQL Server 可以直接连到数据库呢,因为微软己经把“SQL Server 的通讯软件”集成到 Windows 中了。装好通讯软件,我们要进行配置才可以正确的连接到服务器。打开 Net Configuration Assistance,出现以下画面:

 

 

 

图一

 

 在“监听程序配置”和“命名方法配置”两项保默认,在“本地网络服务名配置”要注意,选择本地网络服务名配置,保持默认到配置服务器这一步,如下:

 

 

 

图二

 

 注意此服务器的名字为 ORACLE 数据库的 SID,我这里是 mike。再下一步是选择协议,一般为TCP,下一步是输入主机名,为服务器的 IP 或 NETBIOS NAME。

 

 

 

图三

 

 要保证能 PING 通主机名。

 

 

图四

 

 下一步是测试,最好测试成功,如果不成功,从三个方面入手:

 检查 ORACLE 服务器是否启动;

 检查 SID 是否正确;

 和主机之间的网络是否连通;

 用户名和密码没错, 初始为scott/tiger;

 现在用VC新建一个基于对话框的工程。我们用ADO连接数据库,在 stdafx.h中加入:

 

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

 在 App 的 Initialize() 函数中加入:

 

 try

 {

 m_pConnection.CreateInstance(__uuidof(Connection));

 m_pConnection->Open("Provider=MSDAORA.1;Data Source=mike;","scott","tiger",adModeUnknown);

 }

 catch(_com_error e)

 {

 AfxMessageBox(e.ErrorMessage());

 }

 m_pRecordset.CreateInstance(__uuidof(Recordset));

 m_pRecordset->open(("select * from yourtables",

 m_pConnection.GetInterfacePtr(),

 adOpenDynamic,

 adLockOptimistic,

 adCmdText));

 其余和普通的ADO数据库操作一样......

0
相关文章