Search code examples
.netentity-frameworkmappingado.net-entity-data-modeledmx

load entire db to data model?


I've decided to use the entity framework as data layer.
I have more then 200 tables, and two questions:
1. When creating the data model (*.edmx) - should I include all tables (entire db)?
2. Later, will I be able add tables to the data model?


Solution

  • I agree with @BrokenGlass. VS 2010 SP1 should have improved performance of the designer which works much better with larger models but still 200 tables in single model is too many.

    ADO.NET team published two articles about working with large models: Part 1 and Part 2. Generally these articles are not only about splitting your mapping into multiple EDMXs but also about sharing some common entities in multiple EDMXs which can be really helpful. Without this sharing you can't an reference entity from one EDMX in another EDMX. Also each EDMX will have its own ObjectContext. Spliting a mapping into multiple EDMX should be based on some architecture decission: for example split by a component or split by an aggregate root. Anyway using multiple EDMX will increase the complexity of the application and you must still understand that EF features don't work accross multiple EDMXs - so for example you can't create a linq-to-entities query on top of entities mapped in different EDMXs.

    I answered a question where I describe some hack how to use multiple EDMX files in the single ObjectContext but I recommend not using that solution until you must - the only meaningful usage of that solution is separate EDMX for entities updated from database and separate EDMX for SSDL defined manually (for exemple custom DefiningQuery). The reason is that Update from database function will delete your changes so it is helpful to keep them separately in EDMX which is never updated.