Почему основное ядро ​​объекта использует имя класса вместо имени таблицы при создании имени для ограничения иностранногC#

Место общения программистов C#
Ответить
Гость
 Почему основное ядро ​​объекта использует имя класса вместо имени таблицы при создании имени для ограничения иностранног

Сообщение Гость »

У меня есть эти классы модели (удаленные не связанные детали): < /p>

Код: Выделить всё

internal class RelationTypeModel
{
public Guid Id { get; init; }
public required string Name { get; init; }

public class  Configurator : IEntityTypeConfiguration
{
public void Configure(EntityTypeBuilder builder)
{
builder.ToTable("graph_relation_types");
builder.Property(r => r.Id)
.HasColumnName("relation_type_id")
.HasValueGenerator();
}
}
}
< /code>
internal class GraphRelationModel
{
public Guid Id { get; init; }
public Guid RelationTypeId { get; init; }
public virtual RelationTypeModel? RelationType { get; init; }

public class Configurator : IEntityTypeConfiguration
{
public void Configure(EntityTypeBuilder builder)
{
builder
.ToTable("graph_relations");

builder.Property(r => r.Id)
.HasColumnName("graph_relation_id")
.HasValueGenerator();

builder.Property(r => r.RelationTypeId)
.HasColumnName("relation_type_id");
}
}
}
После того, как я добавил конструктор в модель, EF Core сгенерировал миграцию, которая изменяет модель моментального снимка, например:


EF Core изменил его на правильное значение. Теперь это изменяет это на недействительный. Я считаю это недействительным, потому что используется имя типа, а не имя таблицы. Почему EF Core делает это?

Код: Выделить всё

internal class DatabaseContext : DbContext
{
public DatabaseContext()
: base()
{
}

public DatabaseContext(DbContextOptions options)
: base(options)
{
}

protected override void OnConfiguring(DbContextOptionsBuilder options)
{
options
.UseSnakeCaseNamingConvention()
.UseLazyLoadingProxies();

options.EnableSensitiveDataLogging(true);
}

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.ApplyConfigurationsFromAssembly(GetType().Assembly);
}

protected override void ConfigureConventions(ModelConfigurationBuilder configurationBuilder)
{
// Remove conventions used for data annotations to boost model building as suggested by EF Core documentation.
// https://learn.microsoft.com/en-us/ef/core/modeling/?source=recommendations#removing-an-existing-convention
var types = typeof(BackingFieldAttributeConvention).Assembly
.GetTypes()
.Where(type => type.Name.EndsWith("AttributeConvention"));

foreach (var conventionType in types)
configurationBuilder.Conventions.Remove(conventionType);
}
}
< /code>
Миграции создаются инструментом CLI: < /p>
dotnet ef migrations add --context "DatabaseContext" test


Подробнее здесь: https://stackoverflow.com/questions/796 ... creating-n
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»