本文是對下文的補充,切勿以為我是全盤復制哦
連接:
http://www.cnblogs.com/wlflovenet/p/4187455.html
Entity Framework6 with Oracle(可實現code first)
本人項目代碼版本
VS2013 Update 4
Oracle 服務端是Oracle11gr2,而后各種Oracle服務端,還有各種客戶端,具體原因不多述,導致本人開發的程序,全部必須使用ODP.NET, Managed Driver
ODP.NET, Managed Driver 分為兩種,一種是自帶在ODP.Net安裝包(此安裝包只分32位安裝版本和64位 XCOPY版本),一種是只有9M的zip包
微軟的Nuget上不是最新的,目前支持EntityFramework (6.0.0.0)的只 有Oracle官網上的ODTwithODAC121021.zip,ODP.NET_Managed121020.zip,兩個版本
PS:上面那段話我已經刪除,原因是最近發現出了新版本的ODP.NET,不僅僅是自帶了托管式驅動,而且還包含了MSI安裝包,並且XCOPY版本的(即時客戶端)也有了32位/64位的啦
地址為:http://www.oracle.com/technetwork/topics/dotnet/downloads/net-downloads-160392.html
在多嘴一句,如果有更新之后,沒有在服務器資源管理器添加新數據連接里看到ODP的托管式驅動/非托管驅動 ,那么有兩種可能
1.你沒有按照下文所說的,加入一個默認的Oracle連接字符串,注冊Oracle的托管式驅動在config里,按照下文修改下config文件即可
2.你的Oracle客戶端/服務端沒有卸載干凈,本機上的Oracle有沖突,那么你就要趕緊清理Oracle的注冊表殘留了(這就是比Linux麻煩的一點),還要檢查系統設置里的Patch里選項,是否還殘留Oracle的安裝目錄調用之類的。
3.讀取數據庫表結構也需要一定的權限,如果權限不足,也會讀取不到任何表(此項待驗證)
解決辦法:
在面那個鏈接地址里,你會看到如下的5個鏈接,
第一個是ODP.NET的安裝客戶端(自帶Oracle客戶端一個,即時客戶端一個),跟安裝了Oracle客戶端性質差不多,但是好像是沒有32位的驅動
會導致PLSQL連接不上,具體你們自己測試就知道了,一般裝這個,就可以在服務器資源管理器添加新數據連接里看到ODP的托管式驅動/非托管驅動,此法通殺vs2010,vs2012,vs2013 一切版本
第四,第五鏈接是最近出的,好像裝了,就會自動給你注冊托管式DLL,並且注冊相關的注冊表事項,是否和第一個鏈接類似,不太清楚,偶也是第一次用,大家自行測試吧
- 32-bit ODAC with Oracle Developer Tools for Visual Studio Downloads
- 32-bit ODAC Xcopy and NuGet Downloads
- 64-bit ODAC Downloads - Oracle Universal Installer and Xcopy
- Oracle Developer Tools for Visual Studio 2015 - MSI Installer
- Oracle Developer Tools for Visual Studio 2013 - MSI Installer
鑒於某些伸手黨同學不太明白我這到底改了哪里,我特意上傳一份我已經支持的config文件內容,
需要注意的一點是,如果是你本機上已經安裝過Oracle 的ODP.Net的其他版本,請自行查看maching.config(也區分32位和64位)中是否有類似下面標紅的地方( <section name="oracle.manageddataaccess.client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />)這樣的注冊
如果沒有,則證明沒有安裝ODP.NET,自己裝一個即可,如果是托管式驅動,則無需此步驟,
如果在其他機器打開源代碼,進行開發的時候,記得把上面那段話先注釋掉,會有沖突
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="oracle.manageddataaccess.client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
</configSections>
<entityFramework>
<defaultConnectionFactory type="Oracle.ManagedDataAccess.EntityFramework.OracleConnectionFactory, Oracle.ManagedDataAccess.EntityFramework, Version=6.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
<providers>
<provider invariantName="Oracle.ManagedDataAccess.Client" type="Oracle.ManagedDataAccess.EntityFramework.EFOracleProviderServices, Oracle.ManagedDataAccess.EntityFramework, Version=6.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="EntityFramework" publicKeyToken="b77a5c561934e089" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<publisherPolicy apply="no" />
<assemblyIdentity name="Oracle.ManagedDataAccess" publicKeyToken="89b483f429c47342" culture="neutral" />
<bindingRedirect oldVersion="4.121.0.0 - 4.65535.65535.65535" newVersion="4.121.2.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="NLog" publicKeyToken="5120e14c03d0593c" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-4.0.0.0" newVersion="4.0.0.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
</startup>
<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.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
</DbProviderFactories>
</system.data>
<oracle.manageddataaccess.client>
<version number="*">
<dataSources>
<dataSource alias="SampleDataSource" descriptor="(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ORCL))) " />
</dataSources>
</version>
</oracle.manageddataaccess.client>
<connectionStrings>
<add name="00_Entities" connectionString="metadata="res://*/Entity Data Model.00.DB_00.csdl|res://*/Entity Data Model.**.**.ssdl|res://*/Entity Data Model.**.**.msl";provider=Oracle.ManagedDataAccess.Client;provider connection string="DATA SOURCE=192.13.11.102:1521/00;PASSWORD=006tsl;PERSIST SECURITY INFO=True;USER ID=00"" providerName="System.Data.EntityClient" />
<add name="TPL_Entities" connectionString="metadata="res://*/Entity Data Model.TPL.DB_TPL.csdl|res://*/Entity Data Model.TPL.DB_TPL.ssdl|res://*/Entity Data Model.TPL.DB_TPL.msl";provider=Oracle.ManagedDataAccess.Client;provider connection string="DATA SOURCE=192.13.11.102:1521/ORCL;PASSWORD=1l;PERSIST SECURITY INFO=True;USER ID=OP0"" providerName="System.Data.EntityClient" />
</connectionStrings>
</configuration>
省略千字,進入正題,如果出現下面這個信息(相信很多人都和我一樣被微軟給迷惑了)
其實是我們基礎學的好不好,此處上文提到園友其實已經給出了解決辦法
那就是修改Web.config;
把
改為
<entityFramework>
<defaultConnectionFactory type="Oracle.ManagedDataAccess.EntityFramework.OracleConnectionFactory, Oracle.ManagedDataAccess.EntityFramework, Version=6.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
<providers>
<provider invariantName="Oracle.ManagedDataAccess.Client" type="Oracle.ManagedDataAccess.EntityFramework.EFOracleProviderServices, Oracle.ManagedDataAccess.EntityFramework, Version=6.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
</providers>
</entityFramework>
記得
<section name="oracle.manageddataaccess.client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" /> 這句話要加到
<configSections> </configSections> 里
如果沒有默認的連接對象,自己手寫個即可
就是 <connectionStrings>
</connectionStrings>里加入一個你自己默認要用的連接字符串即可,完成生成之后,這個刪除都行的

到此步,基本上都能用,我就可恥的隱匿了,要感謝wlf提供了如此好的文章,我只是一個搬運工,謝謝殘冰給與的ef使用指導,感謝死胖子你那腦洞大開的ef bug論
PS:如果發現我文章中的Oracle.ManagedDataAccess版本和我上面提到的文章作者說的版本不一致,那是因為我這個是最新的,最新版本是4.121.2.0
我是64位的win8.1 裝的ODP.Net(這玩意只有32位的),安裝之后,VS2013和VS2010里就會自帶有Oracle.ManagedDataAccess。
Oracle官網地址
http://www.oracle.com/technetwork/topics/dotnet/downloads/net-downloads-160392.html (已更新)
