Search code examples
c#.netlinqentity-framework-4linq-to-entities

Is it possible to get Entity Framework to recognize objects that have been created and not yet saved in database?


Say Table1 is a table with two columns. Table1ID and Name.

If I do the following code...

var Obj1 = new Table1();
Obj1.Name = "hello"
TestDBEntities.AddToTable1(Obj1);

var currObj = Table1.Where(o => o.Name.Contains("hello")).FirstOrDefault();

currObj will return null.

But if I do this

var Obj1 = new Table1();
Obj1.Name = "hello"
TestDBEntities.AddToTable1(Obj1);
**TestDBEntitles.SaveChanges();**

var currObj = Table1.Where(o => o.Name.Contains("hello")).FirstOrDefault();

Then currObj will return the first object I created. This is because that object is in the database.

I'm creating a large batch process and I don't want to save everything to the database until the end. However, I have to do checks like make sure a certain object hasn't already been added etc. which require me to reference these objects before they have been saved to the database.

Is it possible to make LINQ queries in Entity Framework that can be aware of objects that are in memory which have not been saved to database.


Solution

  • Add the created and unsaved objects to a List<T> then filter that list with linq like you did above.

    EDIT: actually, i stand corrected. It looks like you can specify merge options on the ObjectContext.

    TestDBEntities.ObjectStateManager.GetObjectStateEntries(EntityState.Added)
        .Where(o => o.GetType() == typeof(Object1Type) 
               && o => o.Name.Contains("hello"))
        .FirstOrDefault();
    

    the docs.