首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ef核心6/mysql性能问题

ef核心6/mysql性能问题
EN

Stack Overflow用户
提问于 2022-07-02 19:57:15
回答 1查看 83关注 0票数 0

我有一个奇怪的性能问题与ef核心6和MySlq,并希望你可以帮助我发现问题。这是我的装置。

  1. Ef核心6/ Mysql

每个层次结构方法的

  1. 表。这是等级制度:

公共类RealEstate : Property{ }

  1. 存储库模式和UnitOfWork。下面是:

公共接口IUnitOfWork { IDataAccessLayer PropertyRepository { get;} IDataAccessLayer RealEstateRepository { get;}

  1. 这里是我的数据库上下文:

公共类MeerkatContext : IdentityDbContext { public MeerkatContext(DbContextOptions options):base(options) {} public DbSet属性{ get;set;} public DbSet RealEstate { get;set;}

  1. I在"property“表

上定义了以下索引

  1. I表中有100万条记录。

以下是问题所在:

以下查询所需时间少于1秒:

代码语言:javascript
复制
var count1 = await this._unitOfWork.PropertyRepository.CountAsync(x =>
    x.CountryId == 1 && !x.IsBlocked && x.IsPublic);

这个花了10秒:

代码语言:javascript
复制
var count2 = await this._unitOfWork.RealEstateRepository.CountAsync(x =>
     x.CountryId == 1 && !x.IsBlocked && x.IsPublic);

我被踩了。任何帮助都会很感激的。

编辑以在MySql WorkBench中显示查询执行

谢谢

EN

回答 1

Stack Overflow用户

发布于 2022-07-04 13:45:07

如果您想搜索未阻塞的项,请更改逻辑以帮助使用SQL:

代码语言:javascript
复制
AND NOT IsBlocked -- inefficient
AND IsBlocked = 0 -- efficient (using "=" instead of "NOT")
AND NotBlocked -- efficient (flip the name and logic)

一般情况下:在构造SQL时避免使用ORNOT。(这太简单化了。)

然后将这个4列索引添加到表中:

代码语言:javascript
复制
INDEX(CountryId, IsBlocked [or NotBlocked], IsPublic, CategoryName)

查看模式的其余部分以获得类似的更改。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72842079

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档