標籤:ons java tor names user oci 用戶端軟體 ado.net 方法
公司伺服器一直都是使用 .NET+SQLSERVER的開發方式,有個項目需要進行讀取遠程Oracle的需求。由於oracle 基本不會,也是一邊做一遍摸索。
首先是使用工具測試是否已經聯通,因為之前用mysql時都是用的Navicat,所以直接在網上下載了Navicat for Oracle,但是死活都連不上,報試過網上所有的方法,下載inistallclient ,修改OCI,加入環境變數,建立tnsnames.ora都沒用,一直是Cannot load OCI DLL,126錯誤,也試過把Navicat與oracle client以及伺服器的版本全部統一,照樣報錯,最後下載Oracle 官方的sqldeveloper,一次成功,話說還是java的牛逼啊。SQLDeveloper
接著,使用ADO.NET開始做Oracle串連,發布到伺服器上,結果報錯 System.Data.OracleClient需要Oracle用戶端軟體版本8.1.7或更高版本。 試過網上的方案:
1.安裝inistallclient 建立環境變數 ,不行
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)));" /> 還是不行
3.將oci.dll等4個dll放到System32檔案夾下 還是不行
4.安裝了Oracle 11g 完全版,依舊不行
5.使用ODBC方式進行串連,還是不行。。。(試的64位,32位沒試)
最後的最後,使用Visual Studio Nuget下載安裝Oracle.ManagedDataAccess包才成功,而且此包只需要一個DLL和web.config的配置,不需要oracle 用戶端。
在產生的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新手們一個協助吧
未安裝Oracle用戶端的伺服器上,使用ASP.NET遠端連線Oracle