Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
На нашем сайте KnigaRead.com Вы можете абсолютно бесплатно читать книгу онлайн Троелсен Эндрю, "Язык программирования C#9 и платформа .NET5" бесплатно, без регистрации.
modelBuilder.Entity<CreditRisk>(entity =>{ entity.HasOne(d => d.Customer<b>Navigation</b>) .WithMany(p => p!.CreditRisks) .HasForeignKey(d => d.CustomerId) .HasConstraintName("FK_CreditRisks_Customers");<b> entity.OwnsOne(o => o.PersonalInformation,</b><b> pd =></b><b> {</b><b> pd.Property<string>(nameof(Person.FirstName))</b><b> .HasColumnName(nameof(Person.FirstName))</b><b> .HasColumnType("nvarchar(50)");</b><b> pd.Property<string>(nameof(Person.LastName))</b><b> .HasColumnName(nameof(Person.LastName))</b><b> .HasColumnType("nvarchar(50)");</b><b> pd.Property(p => p.FullName)</b><b> .HasColumnName(nameof(Person.FullName))</b><b> .HasComputedColumnSql("[LastName] + ', ' + [FirstName]");</b><b> });</b>});Сущность Customer
Следующим обновляется блок для сущности
CustomerTimeStampmodelBuilder.Entity<Customer>(entity =>{<b> entity.OwnsOne(o => o.PersonalInformation,</b> pd =>
<b> {</b> pd.Property(p => p.FirstName).HasColumnName(nameof(Person.FirstName));
<b> pd.Property(p => p.LastName).HasColumnName(nameof(Person.LastName));</b><b> pd.Property(p => p.FullName)</b><b> .HasColumnName(nameof(Person.FullName))</b><b> .HasComputedColumnSql("[LastName] + ', ' + [FirstName]");</b><b> });</b>});Сущность Make
Для сущности
MakeTimeStampmodelBuilder.Entity<Make>(entity =>{<b> entity.HasMany(e => e.Cars)</b><b> .WithOne(c => c.MakeNavigation!)</b><b> .HasForeignKey(k => k.MakeId)</b><b> .OnDelete(DeleteBehavior.Restrict)</b><b> .HasConstraintName("FK_Make_Inventory");</b>});Сущность Order
Для сущности
OrdernullCustomerOrdermodelBuilder.Entity<Order>(entity =>{ entity.HasOne(d => d.CarNavigation) .WithMany(p => p!.Orders) .HasForeignKey(d => d.CarId) .OnDelete(DeleteBehavior.ClientSetNull) .HasConstraintName("FK_Orders_Inventory"); entity.HasOne(d => d.CustomerNavigation) .WithMany(p => p!.Orders) .HasForeignKey(d => d.CustomerId) .OnDelete(DeleteBehavior.Cascade) .HasConstraintName("FK_Orders_Customers");});Настройте фильтр для свойства
CarNavigationOrdermodelBuilder.Entity<Order>().HasQueryFilter(e => e.CarNavigation!.IsDrivable);Сущность Car
Шаблонный класс содержит конфигурацию для класса
InventoryCarTimeStampMakeNavigationCarsIsDrivabletrue