无法将"MvcMiniProfiler.Data.EFProfiledDbConnection"类型的对象强制转换为"System.Data.SqlClient.SqlConnection"类型

Kha*_*meh 7 c# sql entity-framework mvc-mini-profiler

无法将类型为"MvcMiniProfiler.Data.EFProfiledDbConnection"的对象强制转换为"System.Data.SqlClient.SqlConnection".

我正在尝试升级到MvcMiniProfiler 1.9.0,当我调用MiniProfilerEF.Initialize()时我会继续这样做.我已经删除了system.data配置部分.我不知道我做错了什么.我已经按照网站上的步骤进行了操作,但也许我错过了什么?

我首先使用EF代码4.1并且我将我的connectionstring的名称传递给构造函数以创建我的datacontext.

Web Activator

using Project.Web.App_Start;
using WebActivator;

[assembly: PreApplicationStartMethod(typeof(MiniProfiler), "Start")]

namespace Project.Web.App_Start {
    public class MiniProfiler {
        public static void Start()
        { 
            if (Eco.Environment.IsDevelopment) {
                MiniProfilerEF.Initialize();
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

StructureMap注册表:

using Project.Domain.Repositories;
using StructureMap.Configuration.DSL;

namespace Project.Web.DependencyResolution.Registries {
public class RepositoriesRegistry : Registry {
    public RepositoriesRegistry() {
        For<IProjectDataContext>().HybridHttpOrThreadLocalScoped().Use(() => new ProjectDataContext(Eco.Database.Name));
          }
    }
}
Run Code Online (Sandbox Code Playgroud)

DataContext构造函数:

    public ProjectDataContext(string nameOrConnectionString)
        : base(nameOrConnectionString) {
        Active = new Active(this);
    }
Run Code Online (Sandbox Code Playgroud)

我从配置中删除了system.data dataproviders,因为文档说我只需要调用MiniProfilerEF.Initialize().

**更新

以前在1.7 MvcMiniProfiler中我必须设置Database.DefaultConnectionFactory属性,但我删除了它.Database.DefaultConnectionFactory总是以SqlConnectionFactory的形式返回,不应该是ProfiledConnectionFactory或类似的东西吗?

Ole*_* G. 0

我在这里看到的问题是 ProjectDataContext 将一些数据上下文封装到属性“Active”中,MvcProfiler 代理无法找到该属性。

不仅如此,EFProfiledDbConnection 实际上是 DbConnection 的子级,而不是 SqlConnection 的子级。它是在抽象方面使用不同的Db提供程序,例如MySql,Postgres等。请尝试检查代码中的所有变量,它们应该是DbConnection,而不是SqlConnection(这是MsSql的提供程序)。