使用Code First模式时,会默认添加外键的迁移,外键约束虽然可以保证数据的一致性和完整性,但同样会带来一些问题,比如
- 可能带来一定性能影响,从表中插入或删除数据时,数据库都必须检查外键约束是否仍然有效。
- 可能会给运维带来困难,因为添加、删除或修改外键可能需要修改其他相关表。
如果想要EF默认不生成外键的迁移,可以使用如下方法。
修改EntityFrameworkCoreModule的ConfigureServices
修改前
public override void ConfigureServices(ServiceConfigurationContext context)
{
context.Services.AddAbpDbContext<DbContext>(options =>
{
/* Add custom repositories here. Example:
* options.AddRepository<Question, EfCoreQuestionRepository>();
*/
});
// 。。。其他代码
}
修改后
public override void ConfigureServices(ServiceConfigurationContext context)
{
var configuration = context.Services.GetConfiguration();
context.Services.AddDbContext<DbContext>(options =>
{
options.UseSqlServer(configuration["ConnectionStrings:Default"]);
options.ReplaceService<IMigrationsModelDiffer, MigrationsModelDifferWithoutForeignKey>();
});
context.Services.AddAbpDbContext<DbContext>(options =>
{
/* Add custom repositories here. Example:
* options.AddRepository<Question, EfCoreQuestionRepository>();
*/
});
// 。。。其他代码
}
此时生成的迁移就不会生成外键约束,但仍会保留索引的迁移。
标签:Core,EF,外键,context,Services,迁移,options From: https://www.cnblogs.com/cnblogsName/p/17432692.html