工欲善其事必先利其器,选择一本入门教程也是很重要的,本人使用的也是这位同事推荐的电子工业出版社的<<Oracle 实用教程(第3版)>>郑阿奇主编,可以至这里购买到,我个人还是蛮推荐这本书的,注册之后,可以下载这本书的ppt和实验电子档。
匆匆看完了所有的PPT和其它的rtf文档,打开了实验文档的<<实习4:ASP.NET3.5-Oracle>>,于是各种问题出现了:
实验IDE:VS2012 ultimate 英文版
F5启动时就出现BadImageFormatException
奇怪了去,我下的Oracle本身就是win64_11gR2_database_1of2.zip 和win64_11gR2_database_2of2.zip 这两个解压版的。按照这个黄页的提示,只有可能是我的vS2012是32位的,难不成其所使用的webdev.exe是32的oracleClient? 如果我换成64位的client并改用iis host是不是就可以了呢?抱着试验的心态重新去官网下载了个instantclient-basic-windows.x64-11.2.0.3.0.zip,解压并path向解压文件夹。并且还使改用了IIS承载方式,不曾想却又出现
ORA-12154: TNS: could not resolve the connect identifier specified
这个更无语了,我的SQLPLUS和SQLDeveleper以及OEM都是可以连接的。难道用以下这样的连接字符串不行:

<connectionStrings> <add name="ConnectionString" connectionString="Server=localhost; User ID=system;Password=abcdef;Data Source=orcl" providerName="System.Data.OracleClient"/> </connectionStrings>
打开C:oracle11gr2product11.2.0dbhome_1NETWORKADMIN nsnames.ora文件,发现内容是这样子的:

# tnsnames.ora Network Configuration File: C:oracle11gr2product11.2.0dbhome_1 etworkadmin nsnames.ora # Generated by Oracle configuration tools. LISTENER_ORCL = (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) ORACLR_CONNECTION_DATA = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)) ) (CONNECT_DATA = (SID = CLRExtProc) (PRESENTATION = RO) ) ) ORCL = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcl) ) )
于是我将连接字符串改成如下所示

<connectionStrings> <add name="ConnectionString" connectionString="Server=localhost; User ID=system;Password=abcdef;Data Source=(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = orcl)))" providerName="System.Data.OracleClient"/> </connectionStrings>
然后就好了,出现期待的画面。感觉这个有点坑,为什么会这样子呢?求解于Google的时候,发现海峡对岸有位仁兄说加个TNS_ADMIN字串值在regedit(HKEY_LOCAL_MACHINESOFTWAREORACLEKEY_OraDb11g_home1)中就可以解决,貌似我加了没有什么反应。还有CSDN上面有位哥们说加TNS_ADMIN进环境变量,同样在我机器上没起作用。
总结:Oracle在Windows 64位机器上真的是各种坑啊?特别是.NET开发的人员。感觉Oracle就是一个麻烦物样的。:)