【问题标题】:How to insert primary keyless entity to table?如何将主无键实体插入表?
【发布时间】:2021-10-26 08:12:02
【问题描述】:

我正在使用 15 年的数据库。现在我们的方案是首先使用数据库,将实体插入到主无键表中。我阅读了很多 Microsoft EF Core 文档,例如 https://docs.microsoft.com/en-us/ef/core/modeling/keyless-entity-types?tabs=data-annotations。他们说不支持作为结论。

首先,我像往常一样添加了 HasNokey() 然后它给出了一个例外。之后,我在实体类中添加了虚拟主键,然后添加了 HasKey(x=>x.DummyId) Ignore(x=>x.DummyId) 它。但它再次不起作用。现在我很困惑。

如何处理这个问题伙计们?谢谢你的建议。

【问题讨论】:

  • 能否添加实体的类、相关配置以及表的SQL DDL?在第一次尝试时,我认为将存储过程插入/编辑/删除实体并配置为阅读视图。
  • HasNoKey 好像还可以,我觉得还有一个问题。您能否提供更多详细信息或显示您的代码?
  • 首先,谢谢大家的回复。在遇到我的前辈之后,我工作了将近一天。我们决定创建包含此表的视图并通过存储过程操作表。但是之后,我们明白不需要额外的努力,我们选择了最简单的方法,添加两列作为唯一键。作为结论,Ef core 不支持对无键主表进行操作,因此它会导致创建您的唯一键,这是处理此问题的最简单方法。 @Max

标签: c# entity-framework .net-core


【解决方案1】:

自 5.0 版起,EF Core 不直接支持使用 DbSet 更新、删除和插入无密钥表。

我知道有两种解决方案

原始 SQL 查询

在 EF Core 中,可以执行原始 SQL 命令。您可以创建一个 SQL 命令来执行插入并手动执行它。 Microsoft 文档 (https://docs.microsoft.com/en-us/ef/core/querying/raw-sql) 未涵盖您的确切用例,但您可以直接在 DbContextDatabase 成员上使用原始 SQL 或插值 SQL。

    var ctx = new DbContext(options);
    ctx.Database.ExecuteSqlRaw("INSERT INTO Table_Name .....");

更改数据库架构 您可以将主键列添加到架构中,以便 EF 核心能够按预期使用它来进行更新、插入和删除。概括地说,更改将遵循以下步骤。

  1. 创建一个与旧表相同的新表
  2. 添加一个自动递增的主键列
  3. 将旧表中的数据复制到新表中
  4. 删除旧表
  5. 将新表重命名为旧表的名称

完成后,您需要更改实体定义,如下所示。

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    modelBuilder.Entity<ConfigTemplate>(entity =>
    {
         // Adding the key itself, using the index name as well
         entity.HasKey(e => e.primary_key)
               .HasName("PRIMARY");

         // Adding the index definition is not a required
         entity.HasIndex(e => e.primary_key)
               .HasName("PRIMARY");

         entity.ToTable("config_template");
    }
}

【讨论】:

  • 无法删除表,也感谢推荐。
【解决方案2】:

如果您的无键表有一些其他列可以用作复合键,您可以尝试在 dbcontext 中更新该实体的配置作为解决方法,但我同意使用新主键修改现有表更好解决方案

 modelBuilder.Entity<SampleEntity>(entity =>
 {
    entity.HasKey(e => new { e.Property1, e.Property2  });
 });

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2020-07-21
    • 1970-01-01
    • 1970-01-01
    • 2021-10-25
    • 2018-03-21
    • 2018-04-11
    • 1970-01-01
    相关资源
    最近更新 更多