с помощью EF 7: 1.0.0-RC1-финал,Entity Framework 7: Создание Invalid Column Name
У меня возникли проблемы с EF генерацией запроса должным образом, с использованием базы данных первого подхода - использование эф подмостей для генерировать некоторые свойствам модели, перечисленные в DbContext - как таблицы содержат большое количество столбцов, мне нужно всего лишь несколько, чтобы работать на WebAPI поэтому они колонок отображаются
у меня есть 3 лица, брэнды, Событие и Sessions
Бренды содержит много событий и событий, содержащих множество сеансов
мои модели:
[Table("tblBranding")]
public class Brand
{
[Key]
[Column("brandingId")]
public int BrandId { get; set; }
[Column("BrandingActive")]
public bool Active { get; set; }
[JsonIgnore]
[Column("DeadBrand")]
public bool DeadBrand { get; set; }
[Column("BrandingSiteTitle")]
public string Name { get; set; }
//navigation properties
public virtual ICollection<Event> Events { get; set; }
}
[Table("tblEvents")]
public class Event
{
public int EventId { get; set; }
[Column("eventActive")]
public bool Active { get; set; }
[Column("eventName")]
public string Name { get; set; }
public DateTime EventCloseDate {get;set;}
public int PaxAllocationLimit { get; set; }
//navigation properties
[JsonIgnore]
[Column("brandingId")]
public virtual int BrandId { get; set; }
[JsonIgnore]
[ForeignKey("BrandId")]
public virtual Brand Brand { get; set; }
public virtual ICollection<Session> Sessions { get; set; }
}
[Table("tblEventsDates")]
public class Session
{
[Column("EventDateID")]
public int SessionId { get; set; }
[Column("EventDateName")]
public string Name { get; set; }
[Column("EventDate")]
public DateTime SessionDate { get; set; }
[Column("EventDateTime")]
public DateTime SessionTime { get; set; }
[Column("EventDateMinutes")]
public decimal? SessionDurationInMinutes { get; set; }
[Column("EventDateArrival")]
public DateTime? ArrivalTime { get; set; }
[Column("EventCapacity")]
public int SessionCapacity { get; set; }
//navigation properties
[JsonIgnore]
public virtual int EventId { get; set; }
[JsonIgnore]
public virtual Event Event { get; set; }
}
Мои DbContext
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Event>()
.HasOne(e => e.Brand)
.WithMany(b => b.Events).HasForeignKey(e=>e.BrandId);
modelBuilder.Entity<Event>()
.HasMany(s => s.Sessions)
.WithOne(e => e.Event).HasForeignKey(s => s.EventId);
modelBuilder.Entity<Event>(entity=> {
entity.Property(e => e.EventId).HasColumnName("EventID");
entity.HasKey(e => new{ e.EventId, e.EventCloseDate});
entity.HasIndex(e => e.EventId).HasName("For Full Text Indexing").IsUnique();
entity.Property(e => e.Active).HasDefaultValue(false);
entity.Property(e => e.EventCloseDate)
.HasColumnType("datetime")
.HasDefaultValueSql("'1/1/2038'");
entity.Property(e => e.Name).HasMaxLength(1024);
entity.Property(e => e.PaxAllocationLimit).HasDefaultValue(10000);
});
modelBuilder.Entity<Brand>(entity => {
entity.HasKey(e => e.BrandId);
entity.Property(e => e.Active).HasDefaultValue(false);
entity.Property(e => e.Name)
.IsRequired()
.HasMaxLength(150)
.HasColumnType("varchar");
});
modelBuilder.Entity<Session>(entity => {
entity.HasKey(e => e.SessionId);
entity.Property(e=>e.Name)
.HasMaxLength(250)
.HasColumnType("varchar")
.HasDefaultValue("");
entity.Property(e => e.SessionDurationInMinutes)
.HasColumnType("numeric")
.HasDefaultValue(0m);
});
}
public virtual DbSet<Brand> Brands { get; set; }
public virtual DbSet<Event> Events { get; set; }
public virtual DbSet<Session> Sessions { get; set; }
}
Я использую проект как WebAPI, когда я вызываю Brands, он генерирует следующий SQL:
SELECT [e].[brandingId], [e].[BrandingActive], [e].[DeadBrand], [e].[BrandingSiteTitle]
FROM [tblBranding] AS [e]
WHERE [e].[BrandingActive] = 1
ORDER BY [e].[BrandingSiteTitle], [e].[brandingId]
Microsoft.Data.Entity.Storage.Internal.RelationalCommandBuilderFactory: Information: Executed DbCommand (75ms) [Parameters=[], CommandType='Text', CommandTimeout='30']
SELECT [t].[EventId], [t].[EventCloseDate], [t].[eventActive], [t].[brandingId], [t].[EventId1], [t].[eventName], [t].[PaxAllocationLimit]
FROM [tblEvents] AS [t]
INNER JOIN (
SELECT DISTINCT [e].[BrandingSiteTitle], [e].[brandingId]
FROM [tblBranding] AS [e]
WHERE [e].[BrandingActive] = 1
) AS [e] ON [t].[brandingId] = [e].[brandingId]
ORDER BY [e].[BrandingSiteTitle], [e].[brandingId]
где [t]. [EventId1] имя столбца недопустимо Обратите внимание, что если я прокомментирую следующий код в DbContext - эта ошибка исчезнет, и запрос будет сгенерирован правильно :
modelBuilder.Entity<Event>()
.HasMany(s => s.Sessions)
.WithOne(e => e.Event).HasForeignKey(s => s.EventId);
Я попытался добавить [ForeignKey], [InverseProperty] атрибутов в то время как «пустячный» - это, кажется, не делают разницы
Я также попытался добавить имя столбца в явном виде, как указано here
Я не уверен, что еще попробовать - это начинает происходить только тогда, когда я определяю отношение к сеансам в FluidUI - предложения?
если добавить '.ForSqlServerHasConstraintName ("EventId")' после '.HasForeignKey (s => s.EventId)' что это меняет? – Thomas
все еще генерирует недопустимое имя столбца после добавления ограничения - проверяется добавлением обеих связей с брендами и сеансами – Danish
Звучит глупо, но я столкнулся с этой проблемой после рефарингового имени таблицы Resharper, и я этого не заметил. Переименовано 'ProductCategory' в' ProductCategories' и Resharper реорганизовано также '.ToTable (« ProductCategory »)' to' .ToTable («ProductCategories») ' – guneysus