本系列原创博客代码已在EntityFramework6.0.0测试通过,转载请标明出处

在DbContext首次调用的时候,会很慢,甚至会有5,6秒的等待,通常称为冷查询。再次调用的时候,几毫秒就能请求完。原因是首次调用的时候,DbContext会验证模型,缓存视图信息等操作。我们可以提前预生成视图来缓解延迟。

/// <summary>
/// dbcontext预热
/// 
/// </summary>
private void PreLoad<TDbContext>() where TDbContext:DbContext,new()
{
    using (var dbcontext = new TDbContext())
    {
        var objectContext = dbcontext.GetObjectContext();
        var mappingCollection = (StorageMappingItemCollection)objectContext.MetadataWorkspace.GetItemCollection(DataSpace.CSSpace); 
        mappingCollection.GenerateViews(new List<EdmSchemaError>());
    }  //对程序中定义的所有DbContext逐一进行这个操作
}

dbcontext.GetObjectContext()方法的实现参考上篇博客 EntityFramework进阶(一)- DbContext与ObjectContext互转

 

相关文章:

  • 2021-04-26
  • 2021-06-20
  • 2021-11-19
  • 2022-12-23
  • 2022-12-23
  • 2021-07-09
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-06-10
  • 2022-12-23
  • 2021-12-21
  • 2022-12-23
相关资源
相似解决方案