Search code examples
c#entity-frameworkef-database-first

EF6 database first list of entities in memory need to refresh properties with values from database


I haven't been able to find anything that addresses my problem. Here's the scenario. We have an application that generates lists of entities in memory (List) when the application starts. As long as data manipulation is done from within this application, changes are persisted to the database and back to the client application just fine. However, we've encountered a case where the database record that an entity is mapped to in memory of the application could be modified elsewhere outside of the application. These changes aren't seen until the application terminates and is restarted. Could somebody point me in the right direction on how to take an existing entity (or list of entities) and "refresh" the property values with any possible changed values in the underlying database record that it is mapped to?


Solution

  • Entity Framework has a "Refresh" method built into it (see MSDN article here). I think the refresh mode you would want is "Store wins". This will reset all your values in your application with what is currently stored in the DB.