Как установить значение теневого свойства на значение другого свойства при первой вставке?
Я хочу записать время вставки объекта с помощью CreatedAt свойство тени, которое создается как таковое, поскольку оно должно быть непрозрачным для пользователя.
Пока я настраиваю его, оно будет иметь значение по умолчанию (HasDefaultValueSql("GETUTCDATE()")), я бы хотел, чтобы оно соответствовало предоставленному пользователем значению UpdatedAt при вставке.
Кроме того, можно ли сделать так, чтобы оно было доступно только для чтения, поэтому что невозможно изменить его значение, например, EF.Property(x, "CreatedAt") = DateTime.UtcNow?
Я рассматривал сохраненную версию HasComputedColumnSql, но для этого потребуется условный оператор SQL, например [CreatedAt]? [CreatedAt] : [UpdatedAt], который, по моему мнению, не существует.
modelBuilder.Entity
()
.Property(p => p.NameLength)
.HasComputedColumnSql("LEN([LastName]) + LEN([FirstName])", stored: true);
https://learn.microsoft.com/en-us/ef/co ... ed-columns
Объект уведомления:
public sealed record Notification(
AssetType AssetType,
Guid AssetId,
AssetIssue AssetIssue,
Guid OwnerId,
string DisplayName,
string? GivenName,
string? Surname,
string UserPrincipalName)
{
public required NotificationStatus Status { get; set; }
public required int NotificationCount { get; set; }
public required DateTime UpdatedAt { get; set; }
}
IEntityTypeConfiguration:
public void Configure(Microsoft.EntityFrameworkCore.Metadata.Builders.EntityTypeBuilder builder)
{
// Properties
...
builder.Property(p => p.UpdatedAt).HasDefaultValueSql("GETUTCDATE()");
// Shadow Properties
builder.Property("CreatedAt").HasDefaultValueSql("GETUTCDATE()");
...
}
Подробнее здесь: https://stackoverflow.com/questions/793 ... roperty-on
Как установить значение теневого свойства на значение другого свойства при вставке в EF Core? ⇐ C#
Место общения программистов C#
1735895698
Anonymous
Как установить значение теневого свойства на значение другого свойства при первой вставке?
Я хочу записать время вставки объекта с помощью CreatedAt свойство тени, которое создается как таковое, поскольку оно должно быть непрозрачным для пользователя.
Пока я настраиваю его, оно будет иметь значение по умолчанию (HasDefaultValueSql("GETUTCDATE()")), я бы хотел, чтобы оно соответствовало предоставленному пользователем значению UpdatedAt при вставке.
Кроме того, можно ли сделать так, чтобы оно было доступно только для чтения, поэтому что невозможно изменить его значение, например, EF.Property(x, "CreatedAt") = DateTime.UtcNow?
Я рассматривал сохраненную версию HasComputedColumnSql, но для этого потребуется условный оператор SQL, например [CreatedAt]? [CreatedAt] : [UpdatedAt], который, по моему мнению, не существует.
modelBuilder.Entity
()
.Property(p => p.NameLength)
.HasComputedColumnSql("LEN([LastName]) + LEN([FirstName])", stored: true);
https://learn.microsoft.com/en-us/ef/core/modeling/generated-properties?tabs=data-annotations#computed-columns
Объект уведомления:
public sealed record Notification(
AssetType AssetType,
Guid AssetId,
AssetIssue AssetIssue,
Guid OwnerId,
string DisplayName,
string? GivenName,
string? Surname,
string UserPrincipalName)
{
public required NotificationStatus Status { get; set; }
public required int NotificationCount { get; set; }
public required DateTime UpdatedAt { get; set; }
}
IEntityTypeConfiguration:
public void Configure(Microsoft.EntityFrameworkCore.Metadata.Builders.EntityTypeBuilder builder)
{
// Properties
...
builder.Property(p => p.UpdatedAt).HasDefaultValueSql("GETUTCDATE()");
// Shadow Properties
builder.Property("CreatedAt").HasDefaultValueSql("GETUTCDATE()");
...
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79323845/how-can-i-set-the-value-of-a-shadow-property-to-the-value-of-another-property-on[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия