Я связываюсь с этим уже несколько дней, и я в растерянности. Я продолжаю получать < /p>
Экземпляр типа объекта 'lineitemheader' не может быть отслеживается, потому что другой экземпляр с значением ключа '{id: 1}' уже отслеживается. При прикреплении существующих объектов убедитесь, что прикреплен только один экземпляр объекта с данным значением ключа. public async Task SaveReportAsync(ReportModel inputReport, CancellationToken ct = default)
{
await using var db = await _dbContext.CreateDbContextAsync(ct);
var existingReport = await db.ReportModels
.Include(r => r.Header)
.Include(r => r.LineItems)
.ThenInclude(li => li.LineItemHeader)
.Include(r => r.LineItems)
.ThenInclude(li => li.LineItemDetails)
.Include(r => r.LineItems)
.ThenInclude(li => li.LineItemPackingUnits)
.FirstOrDefaultAsync(r => r.Id == inputReport.Id, ct);
if (existingReport == null)
{
// New report — just attach full graph
foreach (var lineItem in inputReport.LineItems)
{
lineItem.ReportModel = null;
if (lineItem.LineItemHeader != null)
lineItem.LineItemHeader.LineItem = lineItem;
foreach (var detail in lineItem.LineItemDetails)
detail.LineItem = lineItem;
foreach (var pu in lineItem.LineItemPackingUnits)
pu.LineItem = lineItem;
}
if (inputReport.Header != null)
{
inputReport.Header.ReportModel = null;
}
db.ReportModels.Add(inputReport);
}
else
{
// Update Header
if (inputReport.Header != null)
{
inputReport.Header.ReportModel = null;
if (existingReport.Header != null)
{
db.Entry(existingReport.Header).CurrentValues.SetValues(inputReport.Header);
}
else
{
inputReport.Header.ReportModelId = existingReport.Id;
existingReport.Header = inputReport.Header;
}
}
// Remove existing line items
db.LineItems.RemoveRange(existingReport.LineItems);
// Add new line items from input
foreach (var lineItem in inputReport.LineItems)
{
lineItem.ReportModel = null;
lineItem.ReportModelId = existingReport.Id;
if (lineItem.LineItemHeader != null)
{
lineItem.LineItemHeader.LineItem = lineItem;
lineItem.LineItemHeaderId = lineItem.LineItemHeader.Id;
}
foreach (var detail in lineItem.LineItemDetails)
detail.LineItem = lineItem;
foreach (var pu in lineItem.LineItemPackingUnits)
pu.LineItem = lineItem;
db.LineItems.Add(lineItem);
}
}
await db.SaveChangesAsync(ct);
}
< /code>
namespace Shipping_Form_CreatorV1.Models;
public class ReportModel
{
public int Id { get; set; }
public ReportHeader Header { get; set; } = null!;
public ICollection LineItems { get; set; } = [];
}
public class ReportHeader
{
public int Id { get; set; }
public string LogoImagePath { get; set; } = string.Empty;
public int OrderNumber { get; set; }
[NotMapped]
public string OrderNumberWithSuffix => $"{OrderNumber}-00";
public int PageCount { get; set; }
public string OrdEnterDate { get; set; }
public string ShipDate { get; set; }
public string SoldToCustNumber { get; set; }
public string SoldToCustomerDisplay => $"Sold To: {SoldToCustNumber}";
public string ShipToCustNumber { get; set; }
public string ShipToCustomerDisplay => $"Ship To: {ShipToCustNumber}";
public string SoldToName { get; set; }
public string SoldToCustAddressLine1 { get; set; }
public string SoldToCustAddressLine2 { get; set; }
public string SoldToCustAddressLine3 { get; set; }
public string SoldToCity { get; set; }
public string SoldToSt { get; set; }
public string SoldToZipCode { get; set; }
public string? SoldToCityStZip => $"{SoldToCity?.Trim()}, {SoldToSt?.Trim()} {SoldToZipCode?.Trim()}";
public string ShipToName { get; set; }
public string ShipToCustAddressLine1 { get; set; }
public string ShipToCustAddressLine2 { get; set; }
public string ShipToCustAddressLine3 { get; set; }
public string ShipToCity { get; set; }
public string ShipToSt { get; set; }
public string ShipToZipCode { get; set; }
public string ShipToCityStZip => $"{ShipToCity?.Trim()}, {ShipToSt?.Trim()} {ShipToZipCode?.Trim()}";
public string CustomerPONumber { get; set; }
public string DueDate { get; set; }
public string SalesPerson { get; set; }
public string CarrierName { get; set; }
public string? ShippingInstructions { get; set; }
private string _freightTerms;
public string FreightTerms
{
get => _freightTerms;
set => _freightTerms = Constants.FreightTermCodes.TryGetValue(value, out var value1) ? value1 : string.Empty;
}
// Navigation properties
public int ReportModelId { get; set; }
public ReportModel ReportModel { get; set; } = null!;
}
public class LineItem
{
public int Id { get; set; }
public int LineItemHeaderId { get; set; }
public LineItemHeader? LineItemHeader { get; set; }
public ObservableCollection LineItemDetails { get;set; } = [];
public ObservableCollection LineItemPackingUnits { get; set; } = [];
public int ReportModelId { get; set; }
public ReportModel ReportModel { get; set; } = null!;
}
using System.ComponentModel.DataAnnotations.Schema;
namespace Shipping_Form_CreatorV1.Models;
public class LineItemHeader
{
public int Id { get; set; }
public decimal LineItemNumber { get; set; }
public string ProductNumber { get; set; }
public string ProductDescription { get; set; }
public decimal OrderedQuantity { get; set; }
public decimal PickOrShipQuantity { get; set; }
public decimal BackOrderQuantity { get; set; }
[NotMapped]
public int OrderedQuantityInt => (int)OrderedQuantity;
[NotMapped]
public int PickOrShipQuantityInt => (int)PickOrShipQuantity;
[NotMapped]
public int BackOrderQuantityInt => (int)BackOrderQuantity;
public LineItem LineItem { get; set; }
}
public class LineItemDetail
{
public int Id { get; set; }
public decimal ModelItem { get; set; }
public decimal NoteSequenceNumber { get; set; }
public string? NoteText { get; set; }
public string? PackingListFlag { get; set; }
public string? BolFlag { get; set; }
public int LineItemId { get; set; }
public LineItem LineItem { get; set; } = null!;
}
public class LineItemPackingUnit
{
public int Id { get; set; }
public int Quantity { get; set; }
public string? CartonOrSkid { get; set; }
public int LineNumber { get; set; }
public string? TypeOfUnit { get; set; }
public int Weight { get; set; }
public int LineItemId { get; set; }
public LineItem LineItem { get; set; } = null!;
}
Подробнее здесь: https://stackoverflow.com/questions/797 ... -framework
Тип объекта не может быть отслеживается ошибка - структура сущности ⇐ C#
Место общения программистов C#
-
Anonymous
1756918761
Anonymous
Я связываюсь с этим уже несколько дней, и я в растерянности. Я продолжаю получать < /p>
Экземпляр типа объекта 'lineitemheader' не может быть отслеживается, потому что другой экземпляр с значением ключа '{id: 1}' уже отслеживается. При прикреплении существующих объектов убедитесь, что прикреплен только один экземпляр объекта с данным значением ключа. public async Task SaveReportAsync(ReportModel inputReport, CancellationToken ct = default)
{
await using var db = await _dbContext.CreateDbContextAsync(ct);
var existingReport = await db.ReportModels
.Include(r => r.Header)
.Include(r => r.LineItems)
.ThenInclude(li => li.LineItemHeader)
.Include(r => r.LineItems)
.ThenInclude(li => li.LineItemDetails)
.Include(r => r.LineItems)
.ThenInclude(li => li.LineItemPackingUnits)
.FirstOrDefaultAsync(r => r.Id == inputReport.Id, ct);
if (existingReport == null)
{
// New report — just attach full graph
foreach (var lineItem in inputReport.LineItems)
{
lineItem.ReportModel = null;
if (lineItem.LineItemHeader != null)
lineItem.LineItemHeader.LineItem = lineItem;
foreach (var detail in lineItem.LineItemDetails)
detail.LineItem = lineItem;
foreach (var pu in lineItem.LineItemPackingUnits)
pu.LineItem = lineItem;
}
if (inputReport.Header != null)
{
inputReport.Header.ReportModel = null;
}
db.ReportModels.Add(inputReport);
}
else
{
// Update Header
if (inputReport.Header != null)
{
inputReport.Header.ReportModel = null;
if (existingReport.Header != null)
{
db.Entry(existingReport.Header).CurrentValues.SetValues(inputReport.Header);
}
else
{
inputReport.Header.ReportModelId = existingReport.Id;
existingReport.Header = inputReport.Header;
}
}
// Remove existing line items
db.LineItems.RemoveRange(existingReport.LineItems);
// Add new line items from input
foreach (var lineItem in inputReport.LineItems)
{
lineItem.ReportModel = null;
lineItem.ReportModelId = existingReport.Id;
if (lineItem.LineItemHeader != null)
{
lineItem.LineItemHeader.LineItem = lineItem;
lineItem.LineItemHeaderId = lineItem.LineItemHeader.Id;
}
foreach (var detail in lineItem.LineItemDetails)
detail.LineItem = lineItem;
foreach (var pu in lineItem.LineItemPackingUnits)
pu.LineItem = lineItem;
db.LineItems.Add(lineItem);
}
}
await db.SaveChangesAsync(ct);
}
< /code>
namespace Shipping_Form_CreatorV1.Models;
public class ReportModel
{
public int Id { get; set; }
public ReportHeader Header { get; set; } = null!;
public ICollection LineItems { get; set; } = [];
}
public class ReportHeader
{
public int Id { get; set; }
public string LogoImagePath { get; set; } = string.Empty;
public int OrderNumber { get; set; }
[NotMapped]
public string OrderNumberWithSuffix => $"{OrderNumber}-00";
public int PageCount { get; set; }
public string OrdEnterDate { get; set; }
public string ShipDate { get; set; }
public string SoldToCustNumber { get; set; }
public string SoldToCustomerDisplay => $"Sold To: {SoldToCustNumber}";
public string ShipToCustNumber { get; set; }
public string ShipToCustomerDisplay => $"Ship To: {ShipToCustNumber}";
public string SoldToName { get; set; }
public string SoldToCustAddressLine1 { get; set; }
public string SoldToCustAddressLine2 { get; set; }
public string SoldToCustAddressLine3 { get; set; }
public string SoldToCity { get; set; }
public string SoldToSt { get; set; }
public string SoldToZipCode { get; set; }
public string? SoldToCityStZip => $"{SoldToCity?.Trim()}, {SoldToSt?.Trim()} {SoldToZipCode?.Trim()}";
public string ShipToName { get; set; }
public string ShipToCustAddressLine1 { get; set; }
public string ShipToCustAddressLine2 { get; set; }
public string ShipToCustAddressLine3 { get; set; }
public string ShipToCity { get; set; }
public string ShipToSt { get; set; }
public string ShipToZipCode { get; set; }
public string ShipToCityStZip => $"{ShipToCity?.Trim()}, {ShipToSt?.Trim()} {ShipToZipCode?.Trim()}";
public string CustomerPONumber { get; set; }
public string DueDate { get; set; }
public string SalesPerson { get; set; }
public string CarrierName { get; set; }
public string? ShippingInstructions { get; set; }
private string _freightTerms;
public string FreightTerms
{
get => _freightTerms;
set => _freightTerms = Constants.FreightTermCodes.TryGetValue(value, out var value1) ? value1 : string.Empty;
}
// Navigation properties
public int ReportModelId { get; set; }
public ReportModel ReportModel { get; set; } = null!;
}
public class LineItem
{
public int Id { get; set; }
public int LineItemHeaderId { get; set; }
public LineItemHeader? LineItemHeader { get; set; }
public ObservableCollection LineItemDetails { get;set; } = [];
public ObservableCollection LineItemPackingUnits { get; set; } = [];
public int ReportModelId { get; set; }
public ReportModel ReportModel { get; set; } = null!;
}
using System.ComponentModel.DataAnnotations.Schema;
namespace Shipping_Form_CreatorV1.Models;
public class LineItemHeader
{
public int Id { get; set; }
public decimal LineItemNumber { get; set; }
public string ProductNumber { get; set; }
public string ProductDescription { get; set; }
public decimal OrderedQuantity { get; set; }
public decimal PickOrShipQuantity { get; set; }
public decimal BackOrderQuantity { get; set; }
[NotMapped]
public int OrderedQuantityInt => (int)OrderedQuantity;
[NotMapped]
public int PickOrShipQuantityInt => (int)PickOrShipQuantity;
[NotMapped]
public int BackOrderQuantityInt => (int)BackOrderQuantity;
public LineItem LineItem { get; set; }
}
public class LineItemDetail
{
public int Id { get; set; }
public decimal ModelItem { get; set; }
public decimal NoteSequenceNumber { get; set; }
public string? NoteText { get; set; }
public string? PackingListFlag { get; set; }
public string? BolFlag { get; set; }
public int LineItemId { get; set; }
public LineItem LineItem { get; set; } = null!;
}
public class LineItemPackingUnit
{
public int Id { get; set; }
public int Quantity { get; set; }
public string? CartonOrSkid { get; set; }
public int LineNumber { get; set; }
public string? TypeOfUnit { get; set; }
public int Weight { get; set; }
public int LineItemId { get; set; }
public LineItem LineItem { get; set; } = null!;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79754798/entity-type-cannot-be-tracked-error-entity-framework[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия