创建连接如下
var conn = new EFProfiledDbConnection(DbConnections.GetsqlConnection(),MiniProfiler.Current); return new MyDbContext(conn,true);
当尝试使用DbContext检索数据时,将返回以下错误:
Unable to determine the provider name for connection of type 'StackExchange.Profiling.Data.EFProfiledDbConnection'.`
<system.data> <DbProviderFactories> <remove invariant="StackExchange.Profiling.Data.ProfiledDbProviderFactory" /> <add name="StackExchange.Profiling.Data.ProfiledDbProviderFactory" invariant="StackExchange.Profiling.Data.ProfiledDbProviderFactory" description="StackExchange.Profiling.Data.ProfiledDbProviderFactory" type="StackExchange.Profiling.Data.ProfiledDbProviderFactory,MiniProfiler,Version=2.0.2.0,Culture=neutral,PublicKeyToken=b44f9351044011a3" /> </DbProviderFactories> </system.data>
这没有帮助.我也尝试过使用MiniProfiler.EntityFramework中不同的EFProviderFactories的变体,但是无法让任何一个工作.
如果我尝试运行MiniProfilerEF.Initialize();在App_Start中,当尝试访问DB时,我会收到以下错误消息:
Code generated using the T4 templates for Database First and Model First development may not work correctly if used in Code First mode. To continue using Database First or Model First ensure that the Entity Framework connection string is specified in the config file of executing application. To use these classes,that were generated from Database First or Model First,with Code First add any additional configuration using attributes or the DbModelBuilder API and then remove the code that throws this exception.
从web.config中删除DbProviderFactories部分并运行MiniProfilerEF.Initialize_EF42();在App_Start中导致原始错误.
由于MiniProfiler页面说MiniProfilerEF.Initialize()仅用于代码,这似乎不是要走的路.
其他搜索没有给我任何其他的东西要尝试,除了添加到Web.Config的部分.有关如何进行的建议?目标是能够使用Mvc MiniProfiler分析的Model First DbContext.
解决方法
public class MvcApplication : HttpApplication { protected void Application_Start() { AreaRegistration.RegisterallAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); AuthConfig.Registerauth(); AutomapperConfig.RegisterMappings(); MiniProfiler.Settings.sqlFormatter = new StackExchange.Profiling.sqlFormatters.sqlServerFormatter(); MiniProfilerEF.Initialize(); } protected void Application_BeginRequest() { if (Request.IsLocal) { MiniProfiler.Start(); } } protected void Application_EndRequest(object sender,EventArgs e) { MiniProfiler.Stop(false); } }
我定期实例化我的上下文:
var _database = new DinoContext(_connectionString);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。