Как установить значение теневого свойства на значение другого свойства при вставке в EF Core?C#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Как установить значение теневого свойства на значение другого свойства при вставке в EF Core?

Сообщение 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/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
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Ошибка Bad Gateway (502) при вызове API Core Core .NET .NET из другого API Core .NET .NET .NET .NET
    Anonymous » » в форуме C#
    0 Ответы
    10 Просмотры
    Последнее сообщение Anonymous
  • Ошибка Bad Gateway (502) при вызове API Core Core .NET .NET из другого API Core .NET .NET .NET .NET
    Anonymous » » в форуме C#
    0 Ответы
    14 Просмотры
    Последнее сообщение Anonymous
  • EF Core: ошибка при вставке строки в базу данных с ошибкой ограничения FK
    Anonymous » » в форуме C#
    0 Ответы
    26 Просмотры
    Последнее сообщение Anonymous
  • EF Core: ошибка при вставке строки в базу данных с ошибкой ограничения FK
    Anonymous » » в форуме C#
    0 Ответы
    29 Просмотры
    Последнее сообщение Anonymous
  • React MUI V5 createTheme не отображает тему в точке монтирования теневого корня
    Гость » » в форуме CSS
    0 Ответы
    42 Просмотры
    Последнее сообщение Гость

Вернуться в «C#»