English 中文(简体)
Entity Framework v4 - what s the difference between POCO vs Code-Only?
原标题:

i m under the impression that

  • EF with POCO: allows you to map your own POCO s to the entities on the model (.edmx).
  • EF Code-Only: no edmx / model designer (ie. CSDL/SSDL/MSL (collectively EDMX) metadata). Still POCO s but the mappings, relationships, navigation, etc are all manually coded (hence the code-only, description).

If this description of the two concepts is (more or less) correct, why would someone what to do a Code-Only instead of EF with POCO?

Both are doing POCO s, but the 2nd one has the extra burden of having to also do the mapping, manually?

最佳回答
  1. Code only is great if you want to write the mapping by hand without having to slog through XML. Also the edmx designer gets unwieldy after 50 or so models, it s just a burden to use that way.

When something goes wrong inside your mapping XML its really a PITA to dig around in the xml to make the fixes you need. Also the designer breaks if you start manually editing your xml in certain scenarios.

Now I don t know the details but the designer in EF1 didn t support all the available mapping options. The EF4 designer has some improvements ( one way relationships come to mind ) but I m not sure if it has feature parity with manual mappings.

  1. Yes.
问题回答

The only thing I would add to jfar s answer is that with Code-Only you don t have to create mappings.

Mappings can be inferred by convention most of the time.

The point about view pre-generation is important. I haven t heard that Microsoft have any intention to provide pre-generation for code-only. If someone knows different please post.

I have used code-only for 400 tables as part of an investigation on whether to go with EF4 or NHibernate and there is an 80 second initial delay for view generation - exactly the same as when using the designer, but with the designer view pre-generation is possible which brought the delay down to 10 seconds. If you are not happy splitting your model and you have over about 75 tables don t go code-only.

I don t think that Code-Only presently lets you pregenerate views, so there may be a performance cost. This might change before release, though.

Something else that has not been mentioned is that you get full compile-time checking of your syntax when using Code Only. If you are using the visual designer with EDMX, you get some compile-time checking, but it is limited. For larger models, EDMX gets extremely unweildy, and manually writing the CSDL, SSDL, and MSL is the only decent way to manage extremely large models with XML mappings. You don t get any compile-time checking if you manually manage your mappings.

With Code Only, you have the benefit of complete compile time checking for models of any size, even if you have hundreds or thousands of entities you need to work with. It also results in less "clutter", as your end product is all compiled assemblies, rather than a mix of assemblies and various kinds of xml files.





相关问题
Manually implementing high performance algorithms in .NET

As a learning experience I recently tried implementing Quicksort with 3 way partitioning in C#. Apart from needing to add an extra range check on the left/right variables before the recursive call, ...

Anyone feel like passing it forward?

I m the only developer in my company, and am getting along well as an autodidact, but I know I m missing out on the education one gets from working with and having code reviewed by more senior devs. ...

How do I compare two decimals to 10 decimal places?

I m using decimal type (.net), and I want to see if two numbers are equal. But I only want to be accurate to 10 decimal places. For example take these three numbers. I want them all to be equal. 0....

Exception practices when creating a SynchronizationContext?

I m creating an STA version of the SynchronizationContext for use in Windows Workflow 4.0. I m wondering what to do about exceptions when Post-ing callbacks. The SynchronizationContext can be used ...

Show running instance in single instance application

I am building an application with C#. I managed to turn this into a single instance application by checking if the same process is already running. Process[] pname = Process.GetProcessesByName("...

How to combine DataTrigger and EventTrigger?

NOTE I have asked the related question (with an accepted answer): How to combine DataTrigger and Trigger? I think I need to combine an EventTrigger and a DataTrigger to achieve what I m after: when ...

热门标签