public async Task Update(T updatedRecord, string operatorId) where T : BaseUser
{
var operator = await MyContext.TUsers.FirstOrDefaultAsync(u => u.userId == operatorId);
if (operator == null) throw new BusinessException("Action denied");
TUsers oldRecord = await SearchUser(updatedRecord.Id);
if (fichaAntiga == null) throw new BusinessException("User not found");
updatedRecord.UpdatedOn = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.FFF");
updatedRecord.UpdatedBy = operator.Id;
MyContext.Entry(oldRecord).CurrentValues.SetValues(updatedRecord);
await MyContext.SaveChangesAsync();
return new TUsers();
}
< /code>
Я переопределял метод SaveChangesAsync в MyContext, чтобы получить старую запись и новую, и записать их в коллекции MongoDB. Но проблема в том, что оба свойства показывают новую запись. Вот мой переопределение < /p>
public override Task SaveChangesAsync(bool acceptAllChangesOnSuccess, CancellationToken cancellationToken = default)
{
var modifiedEntities = ChangeTracker.Entries()
.Where(p => p.State == EntityState.Modified).ToList();
foreach (var change in modifiedEntities)
{
Console.WriteLine(change.OriginalValues);
Console.WriteLine(change.CurrentValues);
}
return base.SaveChangesAsync(acceptAllChangesOnSuccess, cancellationToken);
}
Я поместил точку останова в начале метода и осматриваю значения внутри изменения.>
У меня есть следующий метод обновления, чтобы обновить все поля записи: < /p> [code]public async Task Update(T updatedRecord, string operatorId) where T : BaseUser { var operator = await MyContext.TUsers.FirstOrDefaultAsync(u => u.userId == operatorId); if (operator == null) throw new BusinessException("Action denied");
TUsers oldRecord = await SearchUser(updatedRecord.Id); if (fichaAntiga == null) throw new BusinessException("User not found");
return new TUsers(); } < /code> Я переопределял метод SaveChangesAsync в MyContext, чтобы получить старую запись и новую, и записать их в коллекции MongoDB. Но проблема в том, что оба свойства показывают новую запись. Вот мой переопределение < /p> public override Task SaveChangesAsync(bool acceptAllChangesOnSuccess, CancellationToken cancellationToken = default) { var modifiedEntities = ChangeTracker.Entries() .Where(p => p.State == EntityState.Modified).ToList();
foreach (var change in modifiedEntities) { Console.WriteLine(change.OriginalValues); Console.WriteLine(change.CurrentValues); }
return base.SaveChangesAsync(acceptAllChangesOnSuccess, cancellationToken); } [/code] Я поместил точку останова в начале метода и осматриваю значения внутри изменения.>
У меня есть следующий метод обновления, чтобы обновить все поля записи:
public async Task Update(T updatedRecord, string operatorId) where T : BaseUser
{
var operator = await MyContext.TUsers.FirstOrDefaultAsync(u => u.userId == operatorId);
if...
В Google Earth Engine (GEE), когда я импортирую изображение в ресурс Gee из локального источника, названия полос отображаются как b* (например, b1, b2 и т. д.) вместо исходных названий полос. Есть ли способ гарантировать, что имена каналов в ресурсе...
В Google Earth Engine (GEE), когда я импортирую изображение в ресурс Gee из локального источника, названия полос отображаются как b* (например, b1, b2 и т. д.) вместо исходных названий полос. Есть ли способ гарантировать, что имена каналов в ресурсе...
Я заполняю существующий файл Excel, используя Exceljs. Необходимо снова повторно добавить подтверждения, используя приведенный ниже код (например):
const workbook = new ExcelJS.Workbook();
await workbook.xlsx.load(buffer);
const targetSheet =...