2

現在、ASP.Net MVCプロジェクトでリポジトリパターンを使用しており、次のコードがあります。

    partial class Timesheet : ITimesheet
        {
            TimeSystemDBEntities _db;

            public Timesheet()
            {
                _db = new TimeSystemDBEntities();
            }
            .
            .
             //More Methods
            .
            .

            //Save WorkWeek to database
            private void SaveWorkWeek(WorkWeek wk)
                {
                    //Creating a new test context in attempt to resolve
                    //Error: “An entity object cannot be referenced by multiple instances of IEntityChangeTracker"
                    var testContext = new TimeSystemDBEntities();
                    var newWorkWeek = new WorkWeek();
                    var newStudent = new Student();
                    //Copy contents of wk to newWorkWeek
                    newWorkWeek.Students = newStudent.GetStudent(wk.Students.id);
                    newWorkWeek.MonDate = wk.MonDate;
                    newWorkWeek.MonHours = wk.MonHours;
                    newWorkWeek.TuesDate = wk.TuesDate;
                    newWorkWeek.TuesHours = wk.TuesHours;
                    newWorkWeek.WedDate = wk.WedDate;
                    newWorkWeek.WedHours = wk.WedHours;
                    newWorkWeek.ThursDate = wk.ThursDate;
                    newWorkWeek.ThursHours = wk.ThursHours;
                    newWorkWeek.FriDate = wk.FriDate;
                    newWorkWeek.FriHours = wk.FriHours;
                    newWorkWeek.TempSave = wk.TempSave;

                    testContext.AddToWorkWeek(newWorkWeek); //Exception thrown here
                    testContext.SaveChanges();

                    //Also tried
                    //_db.AddToWorkWeek(newWorkWeek); //Exception thrown here
                    //_db.SaveChanges();

                    //Also tried
                    //_db.detach(wk): //Different exception thrown here: Says it's not in ObjectStateManager
                    //_db.AddToWorkWeek(newWorkWeek); 
                    //_db.SaveChanges();

                    //Also tried
                    //_db.detach(wk.Students): //Different exception thrown here: Says it's not in ObjectStateManager
                    //_db.AddToWorkWeek(newWorkWeek); 
                    //_db.SaveChanges();

                }

    }

StudentクラスとWorkWeekクラスは、それぞれ1対多の関係にあります。上記のサンプルコードのように、デタッチから完全に新しいコンテキストの作成まですべてを試しましたが、オブジェクトを保存できません。デタッチしようとすると、基本的にObjectStateManagerにないことを示します。これは、デタッチするものがないため、元のエラーと矛盾しているように見えます。何が起こっているのかわかりません。助けていただければ幸いです。

4

2 に答える 2

1

@Craig、ありがとう私は実際にそれらのリンクとその解決策をすでに見ていて、それらを実装しようとしましたが成功しませんでした。

次のリンクは、私の問題の解決策を提供してくれました。また、EntityFrameworkに関係するその他のさまざまな問題に関する他の非常に役立つ情報もあります。

EntityFrameworkの落とし穴

于 2010-04-15T15:44:13.013 に答える
0

私はMVCとEntityFrameWorkを初めて使用します。私はたくさん戦った後に同じ問題を抱えましたこの解決策は私のために働きました。それが皆さんのお役に立てば幸いです。

var mediaItem = db.MediaItems.FirstOrDefault(x => x.Id == mediaItemViewModel.Id);
    mediaItem.Name = mediaItemViewModel.Name;
    mediaItem.Description = mediaItemViewModel.Description;
    mediaItem.ModifiedDate = DateTime.Now;
    mediaItem.FileName = mediaItem.FileName;
    mediaItem.Size = KBToMBConversion(mediaItemViewModel.Size);
    mediaItem.Type = mediaItem.Type;

//db.Entry(mediaItem).State = EntityState.Modified;// coment This line
db.SaveChanges();

オブジェクト全体をdbから読み取り、現在のコンテキストで保持しているため、エンティティの状態を変更しようとすると、現在のコンテキストにすでに1つのエンティティがアタッチされていることがわかります。変更の保存を呼び出すだけで保存されます。

于 2014-12-16T11:03:41.123 に答える