sql-server - EF Core 数据库首先使用 HasNoKey

标签 sql-server .net-core entity-framework-core

我有一个 20 年前在我公司创建的数据库表,它仅用于日记,没有 PRIMARY KEY 或 INDEX。我不能改变那张 table 。

我知道我们需要在代码优先的方法中调用 HasNoKey()

但是在这种情况下我如何应用 HasNoKey 呢?因为它是数据库优先的方法。

最佳答案

DbContext 类的 OnModelCreating 方法中,您执行以下操作:

modelBuilder
    .Entity<MyEntity>(builder =>
    {
        builder.HasNoKey();
        builder.ToTable("MY_ENTITY");
    });
在此处阅读更多相关信息:
https://docs.microsoft.com/en-us/ef/core/modeling/keyless-entity-types?tabs=fluent-api

关于sql-server - EF Core 数据库首先使用 HasNoKey,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60096558/

相关文章:

sql-server - 执行计划是每批还是每条语句?

sql - 在复制中处理标识列的最佳方法

c# - HostedService 的多个实例

c# - 如何在使用 '.NETFramework,Version=v4.5.2' 的项目中安装 System.Drawing.Common?

c# - 如何重试与 ASP.NET Core、EF Core 的乐观并发冲突?

c# - 在 SQL Server 上存储 NoSQL 数据?

sql - ALTER 存储过程(不做任何更改)导致其运行速度减慢 20 倍

azure - 发布 .Net Core 3.1.4 项目 + VS 2022 + Azure 时无法配置 Microsoft Identity Platform

c# - Entity Framework - 实体类型之间的关联已被切断问题

c# - EF Core 8 无法创建 'DbContext' 类型的 ''