3

我最近在客户端机器上遇到了以下错误:

每个配置文件中的“DbProviderFactories”部分只能出现一次。

机器配置似乎包含一个重复的 DbProviderFactories 元素。

<system.data>
    <DbProviderFactories>
        <add name="IBM DB2 for i .NET Provider" invariant="IBM.Data.DB2.iSeries" description=".NET Framework Data Provider for IBM i" type="IBM.Data.DB2.iSeries.iDB2Factory, IBM.Data.DB2.iSeries, Version=12.0.0.0, Culture=neutral, PublicKeyToken=9cdb2ebfb1f93a26" />
    </DbProviderFactories>
    <DbProviderFactories />
</system.data>

手动删除这个额外的元素可以解决问题,并且我们的软件可以运行。但是,已要求我们尝试通过忽略我们自己的 app.config 中的重复条目来解决此问题。这是因为很多客户端可能有同样的问题,我们不能修改每个人的配置文件。

我尝试<clear/>在 system.data 部分中添加一个元素,以希望覆盖 machine.config 中已有的内容。但是,这不起作用。

例如

<system.data>
    <clear />
    <DbProviderFactories>
      <add name="Microsoft SQL Server Compact Data Provider 4.0" 
           invariant="System.Data.SqlServerCe.4.0" 
           description=".NET Framework Data Provider for Microsoft SQL Server Compact" 
           type="System.Data.SqlServerCe.SqlCeProviderFactory, System.Data.SqlServerCe, Version=4.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91"/>
    </DbProviderFactories>
  </system.data>

有没有办法以编程方式忽略重复的 DbProviderFactories 元素?

是否存在允许您修改机器配置的 API?

任何人都可以提供帮助或推荐解决方案吗?

亲切的问候

4

3 回答 3

4

我最近在尝试将 SqlServerCe 与实体框架一起使用时遇到了同样的问题。

我已经设法通过使用Entity Framework 6 中提供的基于代码的配置功能来解决这个问题。

您需要做的就是从您的项目中删除<entityframeowrk><system.data>标签,app.config并在您的项目中包含类似于以下内容的类:

using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Data.Entity.SqlServerCompact;
using System.Data.SqlServerCe;

namespace Data
{
    public class DatabaseConfiguration : DbConfiguration
    {
        public DatabaseConfiguration()
        {
            SetExecutionStrategy("System.Data.SqlServerCe.4.0", () => new DefaultExecutionStrategy());
            SetProviderFactory("System.Data.SqlServerCe.4.0", new SqlCeProviderFactory());
            SetProviderServices("System.Data.SqlServerCe.4.0", SqlCeProviderServices.Instance);
        }
    }
}

然后,实体框架会自动为您挑选并使用它。需要注意的一点是 中的配置app.config将覆盖此类中出现的任何内容。

此外,如果您不想在数据层中包含此类,请参阅此处的移动 DbConfiguration 部分。

于 2014-04-17T10:24:47.817 回答
1

我遇到了同样的问题,似乎是由 IBM DB2 驱动程序引起的。

我认为您不能忽略重复的条目:错误不是由您的应用程序引发的,它是由 .NET 框架引发的,它machine.config在读取它时无法验证。

由于验证失败且配置未加载,因此您无法通过任何类型的 API 对其进行操作。

最好的办法是编写一个简单的控制台应用程序,它不使用任何数据提供程序,并通过纯 XML 操作解析和修复配置文件。如果我没记错的话,只有使用数据提供者的应用程序会触发异常,那么您应该可以做到;如果没有,请告诉我,以便我可以更新分析器。

于 2014-03-17T08:52:36.007 回答
0

正如@Albireo 提到的,问题是由安装IBM iAccess for Windows 引起的——特别是.NET Provider for DB2 组件。我在 V7R1 中亲眼目睹了它,但其他人在 V6R1 中也提到了同样的问题。

IBM 已意识到该问题,并在其中一个服务版本中进行了修复。

从 V7R1服务发布文档

针对 APAR SE45767 修复的问题描述:

在未知情况下,安装 .Net 数据提供程序(作为完整或自定义安装类型的一部分)时,machine.config XML 文件发生损坏。损坏被隔离到与 DbProviderFactories 相关的部分 XML 数据 - 并且通常已观察到包括 XML 数据的某些行的重复。

APAR SE45767 更正:

将提供预防性修复,以消除 machine.config 损坏的可能原因。

将不会提供更新已损坏的 machine.config 文件的更正修复程序。如果可能,使用记录在案的本地修复或规避。

APAR SE45767 的规避:

如果不需要 .Net 数据提供程序,则可以通过执行自定义安装并确保不会安装 .Net 数据提供程序来避免此问题。如果需要 .Net 提供程序,则不知道有任何规避。利用本地修复来解决问题。

于 2014-06-17T21:46:19.803 回答