本文是對下文的補充,切勿覺得我是全盤複製哦html
鏈接:數據庫
http://www.cnblogs.com/wlflovenet/p/4187455.htmlwindows
Entity Framework6 with Oracle(可實現code first)服務器
本人項目代碼版本oracle
VS2013 Update 4app
Oracle 服務端是Oracle11gr2,然後各類Oracle服務端,還有各類客戶端,具體緣由很少述,致使本人開發的程序,所有必須使用ODP.NET, Managed Driver tcp
ODP.NET, Managed Driver 分爲兩種,一種是自帶在ODP.Net安裝包(此安裝包只分32位安裝版本和64位 XCOPY版本),一種是隻有9M的zip包
ide
微軟的Nuget上不是最新的,目前支持EntityFramework (6.0.0.0)的只 有Oracle官網上的ODTwithODAC121021.zip,ODP.NET_Managed121020.zip,兩個版本測試
PS:上面那段話我已經刪除,緣由是最近發現出了新版本的ODP.NET,不只僅是自帶了託管式驅動,並且還包含了MSI安裝包,而且XCOPY版本的(即時客戶端)也有了32位/64位的啦
ui
地址爲: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,而且註冊相關的註冊表事項,是否和第一個連接相似,不太清楚,偶也是第一次用,你們自行測試吧
鑑於某些伸手黨同窗不太明白我這到底改了哪裏,我特地上傳一份我已經支持的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 (已更新)