未安裝Oracle用戶端的伺服器上,使用ASP.NET遠端連線Oracle

來源:互聯網
上載者:User

標籤: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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.