EF6,MVC 5和Oracle数据库

时间:2015-10-13 08:31:55

标签: asp.net .net oracle entity-framework

首先,我想为我的英语错误道歉,我是法国人。

我需要帮助,因为我现在已经阻止了几天,我正试图启动我的网络应用程序。我解释说,我正在开发一个新的网络应用程序。这个应用程序如下图所示:

我有1个解决方案,包含2个项目,首先,_DLL项目是库类项目,它是要连接到Oracle数据库 此数据库已正确连接,我可以生成实体以首先创建数据库 _WebSite包含一个MVC设计patern,实际上没什么特别的。

历史记录:

我在VS 2015上创建了这个解决方案,我正在尝试使用实体框架6.1.3。这是安装在两个项目上的 _DLL项目禁止对ODT Oracle,Oracle.ManagedDataAccess和Oracle.ManagedDataAccess.EntityFramework的引用。 安装的ODT版本是12.1.0.2.4(最后一个,10月5日发布,以及VisualStudio 2015的规则)http://www.oracle.com/technetwork/developer-tools/visual-studio/overview/index.html 在这一步之后,我创建了一个EDMX,基于我的标签名称:“Pilier”,juste尝试连接,如果一切正常工作

之后,我在_WebSite项目上添加对:_DLL项目的引用。下一步,使用EF 6为视图调整MVC。

实际上

App.config(_DLL Project)

THREE.PhongMaterial

Web.config(_WebSite Project)

<?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" />
    <section name="Oracle.ManagedDataAccess.Client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
  </configSections>

  <entityFramework>
    <providers>
      <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
      <provider invariantName="Oracle.ManagedDataAccess.Client" type="Oracle.ManagedDataAccess.EntityFramework.EFOracleProviderServices, Oracle.ManagedDataAccess.EntityFramework, Version=6.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
    </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-5.0.0.0" newVersion="5.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>
    </assemblyBinding>
  </runtime>

  <connectionStrings>
    <add name="Entities" connectionString="metadata=res://*/EntityModel.csdl|res://*/EntityModel.ssdl|res://*/EntityModel.msl;provider=Oracle.ManagedDataAccess.Client;provider connection string=&quot;DATA SOURCE=****;PASSWORD=*******;PERSIST SECURITY INFO=True;USER ID=SAGEX&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>


  <system.data>
    <DbProviderFactories>
      <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="4.121.1.0">
      <settings>
        <setting name="AGPD" value="C:\app\client\uadmin\product\12.1.0\client_2\Network\Admin" />
      </settings>
    </version>
  </oracle.manageddataaccess.client>

</configuration>

问题

在这里,一切都变得奇怪和无法解决......当我在我的asp.net网站上吃午饭时,这个错误会附加。:

这是错误:

* Une exception de type'System.InvalidOperationException's'est produite dans mscorlib.dll mais n'apasétégéréedansle code utilisateur

信息supplémentaires:实体框架提供程序类型'Oracle.ManagedDataAccess.EntityFramework.EFOracleProviderServices,Oracle.ManagedDataAccess.EntityFramework,Version = 6.121.2.0,Culture = neutral,PublicKeyToken = 89b483f429c47342'在ADO的应用程序配置文件中注册。无法加载具有不变名称“Oracle.ManagedDataAccess.Client”的.NET提供程序。确保使用了程序集限定名称,并且程序集可供正在运行的应用程序使用。有关详细信息,请参阅http://go.microsoft.com/fwlink/?LinkId=260882。*

我发现有些人有问题,但在不同的网站上没有解决方案的目的,请允许我继续......有人可以帮助我吗? 感谢。

1 个答案:

答案 0 :(得分:1)

Web.config文件加载配置。忽略dll项目文件中的App.config文件,在您的特定情况下,解决方案可以像添加一样简单:

<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>

到您的Web.config文件。您的Web.config文件中也需要存在连接字符串和其他相关配置条目,而不是您的dll项目的App.config文件中。