公司服務器一直都是使用 .NET+SQLSERVER的開發方式,有個項目須要進行讀取遠程Oracle的需求。因爲oracle 基本不會,也是一邊作一遍摸索。html
首先是使用工具測試是否已經聯通,由於以前用mysql時都是用的Navicat,因此直接在網上下載了Navicat for Oracle,可是死活都連不上,報試過網上全部的方法,下載inistallclient ,修改OCI,加入環境變量,新建tnsnames.ora都沒用,一直是Cannot load OCI DLL,126錯誤,也試過把Navicat與oracle client以及服務器的版本所有統一,照樣報錯,最後下載Oracle 官方的sqldeveloper,一次成功,話說仍是java的牛逼啊。SQLDeveloper 下載地址java
接着,使用ADO.NET開始作Oracle鏈接,發佈到服務器上,結果報錯 System.Data.OracleClient須要Oracle客戶端軟件版本8.1.7或更高版本。 試過網上的方案:mysql
1.安裝inistallclient 新建環境變量 ,不行web
2.web.config 鏈接直接寫成 <add name="ClientOracle" providerName="System.Data.OracleClient" connectionString="Password=XXXX;User ID=XXXX;Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=XXXX)(PORT=1521)))(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=ORCL)));" /> 仍是不行sql
3.將oci.dll等4個dll放到System32文件夾下 仍是不行服務器
4.安裝了Oracle 11g 徹底版,依舊不行oracle
5.使用ODBC方式進行鏈接,仍是不行。。。(試的64位,32位沒試)tcp
最後的最後,使用Visual Studio Nuget下載安裝Oracle.ManagedDataAccess包才成功,並且此包只須要一個DLL和web.config的配置,不須要oracle 客戶端。ide
在生成的web.config中工具
<configSections> <section name="oracle.manageddataaccess.client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.122.1.0, Culture=neutral, PublicKeyToken=89b483f429c47342" /> </configSections> <connectionStrings> <add name="OracleDataAccess" connectionString="DATA SOURCE=SampleDataSource;PERSIST SECURITY INFO=True;USER ID=XXXX;Password=XXXX;" providerName="Oracle.ManagedDataAccess.Client" /> </connectionStrings> <system.data> <DbProviderFactories> <remove invariant="Oracle.ManagedDataAccess.Client" /> <add name="ODP.NET, Managed Driver" invariant="Oracle.ManagedDataAccess.Client" description="Oracle Data Provider for .NET, Managed Driver" type="Oracle.ManagedDataAccess.Client.OracleClientFactory, Oracle.ManagedDataAccess, Version=4.122.1.0, Culture=neutral, PublicKeyToken=89b483f429c47342" /> </DbProviderFactories> </system.data> <oracle.manageddataaccess.client> <version number="*"> <dataSources> <dataSource alias="SampleDataSource" descriptor="(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=XXXX)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ORCL))) " /> </dataSources> </version> </oracle.manageddataaccess.client>
只須要修改標紅的部分,就能夠正常使用ADO.NET的方式進行鏈接了,在建立連接時使用 new Oracle.ManagedDataAccess.Client.OracleConnection(strConn)進行。
另外過去經常使用的Oracle.DataAccess(ODP.NET),走的是Unmanaged,須要oci.dll程序庫,所以還須要安裝Oracle Client,並且32位與64位版本是有區分的,Oracle.DataAccess.dll執行時須要存取Oracle客戶端檔案,還要排除NTFS權限問題,Path環境變量等問題,比較繁瑣。
而Managed ODP.NET 不須要安裝Oracle Client 只須要一個Oracle.ManagedDataAccess.dll就能夠,並且是Any CPU 沒必要再爲32位/64位苦惱
雖然此技術早已推出,可是仍是給oracle新手們一個幫助吧