Язык программирования C#9 и платформа .NET5 - Джепикс Филипп - Страница 417
- Предыдущая
- 417/642
- Следующая
private string _color = "Gold";public string Color{ get => _color; set => _color = value;}Аннотации данных Entity Framework
Аннотации данных — это атрибуты С#, которые применяются для дальнейшего придания формы вашим сущностям. В табл. 22.8 описаны самые часто используемые аннотации данных, предназначенные для определения деталей того, как ваши сущностные классы и свойства сопоставляются с таблицами и полями базы данных. Аннотации данных переопределяют любые конфликтующие соглашения. В оставшемся материале главы и книги вы увидите еще много аннотаций, которые можно применять для уточнения сущностей в модели.

В следующем коде показан класс
BaseEntityIdIdIdentityTimeStamptimestamp/rowversionusing System.ComponentModel.DataAnnotations;using System.ComponentModel.DataAnnotations.Schema;public abstract class BaseEntity{<b> [Key, DatabaseGenerated(DatabaseGeneratedOption.Identity)]</b> public int Id { get; set; }<b> [TimeStamp]</b> public byte[] TimeStamp { get; set; }}Вот класс
Carusing System.Collections.Generic;using System.ComponentModel.DataAnnotations;using System.ComponentModel.DataAnnotations.Schema;using Microsoft.EntityFrameworkCore;<b>[Table("Inventory", Schema="dbo")]</b><b>[Index(nameof(MakeId), Name = "IX_Inventory_MakeId")]</b>public class Car : BaseEntity{<b> [Required, StringLength(50)]</b> public string Color { get; set; }<b> [Required, StringLength(50)]</b> public string PetName { get; set; } public int MakeId { get; set; }<b> [ForeignKey(nameof(MakeId))]</b> public Make MakeNavigation { get; set; }<b> [InverseProperty(nameof(Driver.Cars))]</b> public IEnumerable<Driver> Drivers { get; set; }}Атрибут
[Table]Cardbo[Column][Index]MakeId[Required]StringLength[InverseProperty][ForeignKey]Ниже перечислены отличия от соглашений EF Core:
• переименование таблицы из
CarsInventory• изменение типа данных столбца
TimeStampvarbinary(max)timestamp• установка типа данных и допустимости значения
nullColorPetNamenvarchar(max)/nullnvarchar(50)/null• переименование индекса в
MakeIdОстальные используемые аннотации соответствуют конфигурации, определенной соглашениями EF Core.
Если вы создадите миграцию и попробуете ее применить, то миграция потерпит неудачу. СУБД SQL Server не разрешает изменять любой тип данных существующего столбца на
timestampВот как проще всего решить проблему: поместить свойство
TimeStampTimeStampЗакомментируйте свойство
TimeStampdotnet ef migrations add RemoveTimeStamp -o Migrations -c AutoLot.Samples.ApplicationDbContextdotnet ef database update RemoveTimeStamp -c AutoLot.Samples.ApplicationDbContextУберите комментарий со свойства
TimeStampTimeStamptimestampdotnet ef migrations add ReplaceTimeStamp -o Migrations -c AutoLot.Samples.- Предыдущая
- 417/642
- Следующая
