Local Data
The Local property of DBSet provides simple access to the entities that are currently being tracked by the context, and have not been marked as Deleted. Local keeps track of entities whose entity state is added, modified and unchanged. For example:
using System.Data.Entity; class Program { static void Main(string[] args) { using (var ctx = new SchoolDBEntities()) { ctx.Students.Load(); ctx.Students.Add(new Student() { StudentName = "New Student" }); var std1 = ctx.Students.Find(1); // find student whose id = 1 ctx.Students.Remove(std1);// remove student whose id = 1 var std2 = ctx.Students.Find(2); // find student whose id = 1 std2.StudentName = "Modified Name"; // Loop over the students in context's local. Console.WriteLine("In Local: "); foreach (var student in ctx.Students.Local) { Console.WriteLine("Found {0}: {1} with state {2}", student.StudentID, student.StudentName, ctx.Entry(student).State); } // Get all students from db. Console.WriteLine("\nIn DbSet query: "); foreach (var student in ctx.Students) { Console.WriteLine("Found {0}: {1} with state {2}", student.StudentID, student.StudentName, ctx.Entry(student).State); } } } }
In Local :
Found 0: New Student with state Added
Found 2: Modified Name with state Modified
Found 3: Student3 with state UnchangedIn DbSet query:
Found 1: New Student with state Deleted
Found 2: Modified Name with state Modified
Found 3: Student3 with state Unchanged
As you can see in the above output, local keeps track of entities whose state is Added, Modified or Unchanged where as DbSet collection contains all the entities whose state is Deleted, Modified or Unchanged.
Visit MSDN for more information on Local.