温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

EFCORE中异步查询和工作原理以及注释标记的示例分析

发布时间:2021-09-18 09:46:11 来源:亿速云 阅读:123 作者:柒染 栏目:编程语言

EFCORE中异步查询和工作原理以及注释标记的示例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

异步查询 

当在远程数据库中执行查询时,同步查询可能会阻止当前线程,异步查询可避免阻止线程,这有助于避免冻结户端界面, 异步操作还可以增加 Web 应用程序的吞吐量,可以在数据库操作完成前释放线程去处理其他请求。

 EF Core 不支持在同一上下文实例上运行多个并行操作。 应始终等待操作完成,然后再开始下一个操作。 这通常是通过在每个异步操作上使用 await 关键字完成的。 

Entity Framework Core 提供了一组异步扩展方法,可用于执行异步查询。例如:

ToListAsync()、ToArrayAsync()、SingleAsync() ,如果看到 Async 结尾,一般都是异步方法,这也是微软的命名约定,希望您也遵守。 

对于部分 LINQ 运算符(如 Where(...)、OrderBy(...) 等),没有对应的异步版本,因为这些方法仅用于构建 LINQ 表达式树,而未将查询发送到数据库中执行,只有用到结果时才会去数据库查询,这是 IQueryable 天生的特性,之前我们讲过。


public async Task<List<Blog>> GetBlogsAsync()

{

        using (var context = new BloggingContext())

        {

                return await context.Blogs.ToListAsync();

        }

}

  EFCORE中异步查询和工作原理以及注释标记的示例分析

 异步编程 <https://docs.microsoft.com/zh-cn/dotnet/csharp/async> 

查询的工作原理

  1. 查询编写的所由表达式由 EF Core 处理,根据不同的数据库提供程序生成与 LINQ 等效的 SQL 语句。

    A:查询到的数据会被缓存,以便每次执行相同数据查询时耗费性能。

  2. 查询表达式会传递到数据库提供程序
    A:提供程序会识别出查询的哪些部分可以在数据库中求值进行,哪些只能在客户端进行,哪些根本就没办法进行。
    B:对于能进行数据库查询的操作,生成对应的 SQL 语句。
    C:一个或多个查询会被发送到数据库并返回结果集。这里返回的不是实体对象集合,而是数据集。

  3. 对于结果集中的每一项
    A:如果是跟踪查询(默认跟踪),EF 会检查数据项是已存在于跟踪器中。如果是,则返回现有实体,如果不是,则创建实体,并将实体添加到跟踪器中。
    B:如果这个查询是非跟踪查询,EF 会检查数据是否表示此查询结果集中的现有实体,如果是,则会返回现有实体 ,如果不是,则会创建新实体并返回该新实体。 

调用 LINQ 运算符时,只会构建查询在内存中的表示形式。只有在使用结果时,查询才会发送到数据库。

导致查询发送到数据库的最常见操作如下:

  • 在 for 或者 foreach 循环中循环访问结果

  • 使用 ToList、ToArray、Single、Count 等操作

  • 将查询结果数据绑定到 UI 界面时。

查询注释标记

使用 TagWith() 方法对 LINQ 生成的 SQL 语句进行注释,方便阅读。

1

context.Friends.TagWith("This is my spatial query!")

看完上述内容,你们掌握EFCORE中异步查询和工作原理以及注释标记的示例分析的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI