4

SettlementShift のマッピング定義私はしばらくの間この問題に苦労してきましたが、これを解決できません。複数の投稿を読み、いくつかの異なる解決策を試しましたが、何も機能しませんでした. 今、私は立ち止まったように感じており、これについて本当に助けが必要です.

最初に DB と edmx ファイルを使用して EF 5+ を使用しています。DB に 3 つの異なるテーブルがあります: 1. 決済 2. コスト 3. シフト

Settlement には、私の edmx ファイルで Association によって接続された Cost と Shift (リンク テーブルを使用) の両方のコレクションがあります。

DB 内のリンク テーブルを含む決済テーブル 既存の Cost および Shift コレクションへの参照を使用して、データベースに新しい Settlement を挿入する必要があります。挿入しようとしている和解エンティティに含まれるシフトとコストには、関連するすべてのデータが含まれており、いずれも変更されていません (db から取得したものと同じ)。ここでは、エンティティをデータベースに挿入する方法を示します。

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

この問題に関するヘルプは大歓迎です。

コレクションにコストとシフトを追加する方法は次のとおりです。

ページで和解を作成します。

_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();
        }

この Settlement エンティティに Shift を追加する方法がわかります。

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

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

次に、これをリポジトリに送信します(上記の方法を参照)

        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

あなたが新しいものを望まないなら、私はあなたが既存のものを新しいものに再ポイントする必要があると仮定することができるだけShiftsですCostsSettlement

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

OK、これについて「醜い」解決策を思いつきました..しかし、それは解決されました。モデルを 1 つ (決済) -> 多数 (シフトまたはコスト) の関係に変更しました。

新しい Settlement を作成し、これを DB に保存します。DB から各 Shift と Cost を取得し、それぞれの SettlementID を更新し、これらを 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 リクエストの負荷については気にしていません。この場合、それほど高くはありません。

これにはもっと良い解決策があると思いますが、現時点では見つけることができませんでした。

助けてくれてありがとう:)

于 2013-03-05T21:25:43.087 に答える
0

Shiftsこれは、 andCostsコレクションの作成方法に関係していると思います。既に作成されたレコード (つまり、主キーの値が既に設定されている) を追加して新しいSettlementエンティティに保存しようとしていますが、Entity Framework は新しい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 に答える