![](/img/trans.png)
[英]Unable to determine the principal end of the X relationship. Multiple added entities may have the same primary key
[英]Unable to determine the principal end of the etaxiDataModel relationship. Multiple added entities may have the same primary key
我一直在努力解決這個問題一段時間,但我無法解決這個問題。 已閱讀多篇文章並嘗試了幾種不同的解決方案但沒有任何效果。 現在我覺得我已經停下來,真的需要幫助。
我使用EF 5+與DB first和edmx文件。 我的DB中有3個不同的表:1。結算2.成本3.轉移
結算包含在我的edmx文件中由Association連接的Cost和Shift(帶有鏈接表)的集合。
我需要在我的數據庫中插入一個新的結算,並引用已有的Cost和Shift集合。 我試圖插入的我的結算實體中包含的班次和成本包含所有相關數據,並且沒有任何方式被修改(與我從數據庫中檢索的相同)。 這是我將實體插入我的數據庫的方法。
public bool CreateSettlement(Settlement settlement)
{
bool _success;
var _context = new EtaxiEnteties();// ObjectFactory.Get<IETaxiEntitiesContext>();
try
{
var _newSettlement = new Settlement
{
CreateDate = settlement.CreateDate,
Driver = settlement.Driver,
DriverID = settlement.DriverID,
Car = settlement.Car,
CarID = settlement.CarID,
DocPath = settlement.DocPath
};
foreach (var _shift in settlement.Shifts)
{
//var _sh = _context.Shifts.Find(_shift.ShiftID);
//_context.Entry(_sh).CurrentValues.SetValues(_shift);
_newSettlement.Shifts.Add(_shift);
}
foreach (var _cost in settlement.Costs)
{
////var _sh = _context.Costs.Find(_cost.CostID);
////_context.Entry(_sh).CurrentValues.SetValues(_cost);
_newSettlement.Costs.Add(_cost);
}
_context.Settlements.Add(_newSettlement);
_success = _context.SaveChanges() > 0;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return _success;
}
任何有關該問題的幫助都將受到青睞。
以下是我如何將Cost和Shift添加到我的集合中:
我在頁面中創建了一個結算:
_settlement = new Settlement
{
CreateDate = DateTime.Now,
Driver = _driver,
DriverID = _driver.DriverID,
Car = _car,
CarID = _car.CarID,
DocPath = _path
};
然后當我創建一個包含2個獨立網格視圖中選定行的pdf文件時:
foreach (GridDataItem _selectedRow in gwShifts.MasterTableView.Items)
{
if (_selectedRow.Selected)
{
var _shift =
_diaryRepository.GetShiftByID((int) _selectedRow.GetDataKeyValue("ShiftID")).FirstOrDefault();
if (_shift != null)
{
_settlement.Shifts.Add(_shift);
_settlementData.Shifts.Add(_shift);
_settlementData.SplitPercentace = GetTemplateValue(_selectedRow, "lblSplit");
_settlementData.SettlementAmount = GetTemplateValue(_selectedRow, "lblSettlementAmount");
if (_settlementData.Shifts != null)
{
_tableShifts.AddCell(
new PdfPCell(
new Phrase(
_settlementData.Shifts.FirstOrDefault().ShiftDate.ToShortDateString(),
_bodyFont)) {Border = 0});
_tableShifts.AddCell(
new PdfPCell(
new Phrase(
string.Format("{0:c}", _settlementData.Shifts.FirstOrDefault().GrossAmount),
_bodyFont)) {Border = 0});
_tableShifts.AddCell(
new PdfPCell(
new Phrase(
string.Format("{0:c}", _settlementData.Shifts.FirstOrDefault().MoneyAmount),
_bodyFont)) {Border = 0});
_tableShifts.AddCell(new PdfPCell(new Phrase(_settlementData.SplitPercentace, _bodyFont))
{Border = 0});
_tableShifts.AddCell(
new PdfPCell(new Phrase(_settlementData.SettlementAmount, _boldTableFont))
{Border = 0});
_totalAmount.AddRange(new[]
{
Convert.ToInt32(
_settlementData.SettlementAmount.Replace(".", "").
Replace(",", "").Replace("kr", ""))
});
_settlementData.Shifts.Remove(_shift);
}
}
}
}
var _summaryCell =
new PdfPCell(new Phrase("Upphæð: " + string.Format("{0:c}", _totalAmount.Sum()), _boldTableFont))
{
Border = 0,
Colspan = 5,
HorizontalAlignment = Element.ALIGN_RIGHT,
Padding = 5,
BorderWidthTop = 1
};
_tableShifts.AddCell(_summaryCell);
if (_totalAmount.Count != 0)
_totalAmount.Clear();
}
在那里,您可以看到我如何將Shift添加到此結算實體:
var _shift =
_diaryRepository.GetShiftByID((int) _selectedRow.GetDataKeyValue("ShiftID")).FirstOrDefault();
if (_shift != null)
{
_settlement.Shifts.Add(_shift);
然后我把它發送到reporistory(參見上面的方法)
if(_driverRepository.CreateSettlement(_settlement))
{
SetMessage("Uppgjör hefur verið skapað og sent bílstjóra ef e-póstur er skráður á viðkomandi bílstjóra.", "Uppgjör skapað");
pnlSettlement.Visible = false;
pnlDocCreation.Visible = false;
pnlResult.Visible = false;
}
我還嘗試直接將param結算添加到上下文中但得到了類似的錯誤。
我認為這與你如何填充Shifts
and Costs
系列有關。 您正在嘗試添加已創建的記錄(即已設置其主鍵值)以與新的Settlement
實體一起保存,但我認為實體框架並未嘗試創建與新Settlement
相關聯的新記錄實體,而是將它們保存到表中。 在這種情況下,您確實會遇到多個實體具有相同主鍵的情況。
我會嘗試以下(我將僅向您展示使用Shifts
循環,但您應該能夠將它應用於Costs
循環):
foreach (var _shift in settlement.Shifts)
{
var newShift = new Shift { /*Copy all of the values from _shift here*/ };
_newSettlement.Shifts.Add(_shift);
context.Shifts.Add(newShift);
}
如果這不起作用,我建議調試Costs
和Shifts
以確保您在這些集合中沒有任何重復項。
如果您不想要新的Shifts
和Costs
那么我只能假設您需要將現有的轉移重新定位到新的Settlement
foreach (var shift in settlement.Shifts)
{
//either
shift.Settlement = newSettlement;
//or
shift.SettlementId = newSettlement.SettlementId;
//depending on your object model
}
我剛剛意識到我誤解了這個問題。 圖中未顯示2個附加表(成本和轉移)。 問題是嘗試創建將結算與Costs\\Shifts
SettlementCost
和SettlementShift
實體。
好的,想出了一個“丑陋”的解決方案......但它已經解決了。 將模型更改為一個(結算) - >多個(轉移或成本)關系。
我創建了一個新的結算並將其保存到數據庫中。 從每個數據庫更新SettlementID中檢索每個Shift和Cost,並將這些保存到DB。
try
{
var _newSettlement = new Settlement
{
CreateDate = settlement.CreateDate,
DriverID = settlement.DriverID,
CarID = settlement.CarID,
DocPath = settlement.DocPath
};
Add(_newSettlement);
_success = SaveWithSuccess() > 0;
var _settlement = GetAll().FirstOrDefault(x => x.SettlementID == _newSettlement.SettlementID);
if (_success)
{
foreach (var _shift in settlement.Shifts)
{
var _sh = _diaryRepository.GetShiftByID(_shift.ShiftID).FirstOrDefault();
_sh.SettlementID = _settlement.SettlementID;
_diaryRepository.UpdateShift(_sh);
}
foreach (var _cost in settlement.Costs)
{
var _ch = _costRepository.GetCostByID(_cost.CostID);
_ch.SettlementID = _settlement.SettlementID;
_costRepository.UpdateCost(_ch);
}
}
}
不是一個漂亮的,但它解決了這個問題。 我不擔心DB請求加載..在這種情況下不會那么高。
我認為有一個更好的解決方案,但我目前無法找到它。
感謝您的所有努力,以幫助:)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.