sql-server - EF Core 不断抱怨不存在的索引
问题描述
我在运行时收到了来自 EF Core 的一堆日志抱怨,如下所示:
[10:56:14 DBG] The index {'InvoiceId'} was not created on entity type 'CompleteCase' as the properties are already covered by the index {'InvoiceId', 'Code'}.
[10:56:14 DBG] The index {'ReportPeriodId'} was not created on entity type 'FixedBill' as the properties are already covered by the index {'ReportPeriodId', 'MedCompanyTypeId', 'FixedBillTypeId'}.
[10:56:14 DBG] The index {'CasePeriodId'} was not created on entity type 'Invoice' as the properties are already covered by the index {'CasePeriodId', 'ReportPeriodId', 'MedCompanyTypeId'}.
[10:56:14 DBG] The index {'InvoiceId'} was not created on entity type 'InvoiceFixedBillMap' as the properties are already covered by the index {'InvoiceId', 'FixedBillId'}.
[10:56:14 DBG] The index {'MedCompanyDepartmentTypeId'} was not created on entity type 'MedCompanyDepartmentDoctorMap' as the properties are already covered by the index {'MedCompanyDepartmentTypeId', 'MedCompanyDoctorTypeId', 'DoctorSpecialtyTypeId', 'StartDate', 'EndDate'}.
[10:56:14 DBG] The index {'VMPMethodTypeId'} was not created on entity type 'VMPMethodMKBMap' as the properties are already covered by the index {'VMPMethodTypeId', 'MKBTypeId'}.
[10:56:14 DBG] The index {'KSGBaseRateTypeId'} was not created on entity type 'KSGBaseRate' as the properties are already covered by the index {'KSGBaseRateTypeId', 'StartDate', 'EndDate'}.
[10:56:14 DBG] The index {'KSGTypeId'} was not created on entity type 'KSGIndexRate' as the properties are already covered by the index {'KSGTypeId', 'KSGIndexTypeId', 'StartDate', 'EndDate'}.
[10:56:14 DBG] The index {'MedCompanyTypeId'} was not created on entity type 'MedCompanyKSGIndexRate' as the properties are already covered by the index {'MedCompanyTypeId', 'MedCompanyUnitTypeId', 'MedCompanyDepartmentTypeId', 'UMPTypeId', 'KSGIndexTypeId', 'StartDate', 'EndDate'}.
[10:56:14 DBG] The index {'UserId'} was not created on entity type 'UserRole' as the properties are already covered by the index {'UserId', 'RoleId'}.
[10:56:14 DBG] The index {'UserId'} was not created on entity type 'IdentityUserToken<Guid>' as the properties are already covered by the index {'UserId', 'LoginProvider', 'Name'}.
我可以看到这些的原因 - 因为有使用这些列的复合索引,它们使单独的索引无用。这些列都是外键,EF Core 在迁移过程中自动创建。
但是这些索引实际上都不存在于迁移或数据库本身中(代码优先)。我已经非常仔细地检查了。甚至删除了所有迁移并从头开始创建它们 - 没有。但是在运行时我每次都会得到这些。
是否可以忽略或者应该从我这边采取一些行动?
PS 使用 SQL Server 作为数据库提供程序在 3.1.8 上测试。
解决方案
但是这些索引实际上都不存在于迁移或数据库本身中(代码优先)。
当然他们没有,你在这里看到的只是一个警告,告诉你一些索引已从模型中删除(忽略)。可能令人困惑的部分是您没有明确请求此类索引,正如您所说,它们是由 EF 自动创建的(顺便说一句,不能从外部删除),因此 EF Core 不应该警告您。
但是它就是这样啊。不为另一个索引前导的列生成索引是完全可以的。您可以放心地忽略它,并通过添加以下内容来OnConfiguring
覆盖它:
optionsBuilder.ConfigureWarnings(warnings => warnings
.Ignore(CoreEventId.RedundantIndexRemoved);
推荐阅读
- node.js - 添加猫鼬后如何修复nodemon应用程序崩溃
- typescript - 一个非常简单的打字稿项目的Webpack错误
- amazon-s3 - 转义 Presto 中的所有特殊字符
- java - IFileStore 无法从带有重音字符的路径中读取 Eclipse RCP
- mysql - 无法在mysql中的单个查询中更新和选择
- python - 当变量在python的if-condition中定义时,如何在if-condition之后访问变量
- java - 如何在java中模拟时间戳和日期函数?
- pandas - 如何访问pyspark数据框中的动态列
- java - 事务中的更改子集有时在提交后不久不可见
- javascript - 从 JSON 数据(嵌套对象)计算球队的赛季目标