4

SettlementShift 的映射定义我一直在努力解决这个问题一段时间,但无法解决这个问题。阅读了多篇文章并尝试了几种不同的解决方案,但没有任何效果。现在我觉得我已经停下来了,真的需要帮助。

我将 EF 5+ 与 DB first 和 edmx 文件一起使用。我的数据库中有 3 个不同的表:1. 结算 2. 成本 3. 班次

Settlement 在我的 edmx 文件中包含由 Association 连接的 Cost 和 Shift(带有链接表)的集合。

我的数据库中带有链接表的结算表 我需要在我的数据库中插入一个新的 Settlement,并引用已经存在的 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 添加到这个 Settlement 实体:

     var _shift =
                        _diaryRepository.GetShiftByID((int) _selectedRow.GetDataKeyValue("ShiftID")).FirstOrDefault();

                    if (_shift != null)
                    {
                        _settlement.Shifts.Add(_shift);

然后我把它发送到repository(见上面的方法)

        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;   
            }

我还尝试简单地将参数结算直接添加到上下文中,但遇到了类似的错误。

4

3 回答 3

0

我认为这与您填充ShiftsandCosts集合的方式有关。您正在尝试添加已创建的记录(即它们已经设置了主键值)以与新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);
}

如果这不起作用,我建议调试CostsShifts确保您在这些集合中没有任何重复项。

于 2013-02-27T14:18:59.043 回答
0

如果您不想要新的ShiftsCosts那么我只能假设您需要将现有的重新指向新的Settlement

foreach (var shift in settlement.Shifts)
{  
    //either
    shift.Settlement = newSettlement;
    //or
    shift.SettlementId = newSettlement.SettlementId;
    //depending on your object model
}

我刚刚意识到我误解了这个问题。图中未显示 2 个附加表(成本和班次)。问题是试图创建将 Settlement 连接SettlementCost到.SettlementShiftCosts\Shifts

于 2013-02-27T15:20:45.757 回答
0

好的,对此提出了一个“丑陋”的解决方案..但它已经解决了。将模型更改为一个(结算)-> 多个(班次或成本)关系。

我创建了一个新的 Settlement 并将其保存到 DB。从每个数据库更新 SettlementID 中检索每个班次和成本,并将它们保存到数据库。

 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);

                }
            }
        }

不是一个漂亮的,但它解决了这个问题。我不关心数据库请求负载..在这种情况下不会那么高。

我认为有一个更好的解决方案,但我目前无法找到它。

感谢您为帮助所做的所有努力:)

于 2013-03-05T21:25:43.087 回答