- 1、本文档共9页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
VS2008中用OCCI连接Oracle,不需要安装Oracle客户端
VS的初学者,对它不是很熟悉,环境配置搞了无数次,太痛苦了,十分讨厌MS的安装包,又大,而且必须安装后才能用,不象Java的东西,copy过来就可以用,太烦它了。先说一下基本过程吧,1:下载VS2008的安装包,然后一步步安装VS2008,这个过程没什么好说的,一路Next即可.2:下载Oracle的Instant Client文件,需要注意的是,VS2008需要下载相对应的Instant Client,否则不一致时会出错的,这也是MS一个非常烦人的地方,下载地址是:/technology/software/tech/oci/instantclient/htdocs/winsoft.html,在这里需要下载两个包:Instant Client Package - Basic,Instant Client Package - SDK.这两个包都要下载,第一个是基础包,里面有lib和dll文件,第二个是开发时需要的include和lib包.版本建议下载必威体育精装版的版本,因为Oracle的包是向下兼容的。3:下载OCCI的文件,/technology/tech/oci/occi/occidownloads.html(如果前面一个地址找不到,到/technetwork/database/occidownloads-083553.html上去下载,Oracle自己把地址更改了),下载时注意版本匹配.4:将第2步和第3步下载的文件解压开,存放目录随意,例如3个解压开的目录分别为D:\instantclient,D:\sdk,D:\occi,然后删除掉D:\instantclient下面的oraocci11.dll oraocci11.sys两个文件,同时也把d:\sdk\lib\msvc\oraocci11.lib这个文件删除,因为这三个文件的版本是和VS2008中C++编译器版本不匹配,所以需要删除.5:设置环境变量,把D:\occi也加到环境变量的path里面,而且它必须是第一个,同时将D:\instantclient加到环境变量path里面.6:启动安装好的VS2008,然后将D:\sdk\include加到C++的Include目录中,将d:\sdk\lib\msvc和D:\occi这两个路径加到lib的引用路径中去.这样大体上的环境基本上配置完毕了.7:新建一个WIN32的Console项目,然后在主类里面添加如下代码片断后进行编译,一般是没有问题的.#includeiostream#includeocci.husing namespace oracle::occi;using namespace std;try{const string userName = easupdate;const string password = easupdate;const string connectString = //7:1521/orcl;oracle::occi::Environment *env = oracle::occi::Environment::createEnvironment(ZHS16GBK,UTF8);{Connection *conn = env-createConnection(userName, password, connectString);?? ??? ?? ?Statement *stmt = conn-createStatement(select fid,fdesc_l2,fdesc_l3 from t_bas_param);ResultSet *rs = stmt-executeQuery();while (rs-next()){string l1=rs-getString(1);string l2=rs-getString(2);string l3=rs-getString(3);cout 表空间名称:l1? 内容:l2? 日志:l3endl;} stmt-closeResultSet(rs);conn-terminateStatement(stmt);env-terminateConnection(conn);}oracle::occi::Environment::terminateEnvironment(env);}catch (SQLException sqlExcp){cerr sqlExcp.getErrorCode() : sqlExcp.getMessage() endl;}上面这种做法对一般的VS项目没什么特别需要注意的地方,基本上按过程操作都可以通过,但是在实际的开发过程中需要一些GUI的界面开
文档评论(0)