Код: Выделить всё
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 делает это?
Код: Выделить всё
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
Мобильная версия