views:

4955

answers:

5

I'm getting ready to start a new project and I've been researching the entity framework. My question is what is the best strategy for validating the entities? Other projects I've worked on have used attributes for most of the validation, but obviosuly this is not possible in the entity framework. Is the only way to do this by handling the partial methods in the property setters? All advice is much appreciated.

+4  A: 

I have not actually used the Entity framework before but a quick search indicates that you have several options.

1) Validate at another layer in your application

Always an option, I just thought I would throw it out there explicitly.

2) Hook into the OnChanged events of the Entity then perform validation

Likely brittle and would become confusing/slow after if you have many different properties things that can change for each entity.

3) Implement partial methods to validate property changes

According to this post and this walkthrough there are partial methods available for validation. This seems like your best option as it is not very intrusive and you can selectively implement the validation you want.

I hope that helps. Good luck.

smaclell
How are #2 and #3 any different? The partial methods it generates are the OnChanged events ... unless I am missing something.
jcm
You may be correct. It has been a long time since I have even looked at EF.
smaclell
I read #2 and #3 as entity- and property-level validation, respectively. These two strategies have different purposes, of course: entity-level validation tests the validity all of the properties together (eg. that mutually exclusive properties are not both set), whereas property-level validation considers only the content of a single property at a time (eg. that an email address is of the correct form).
ladenedge
+1  A: 

If you use ASP.NET MVC, then you could use Validation Application Block or the System.ComponentModel.DataAnnotations. The articles Using Data Annotations and Using Application Block show how to do them using Linq, but the usage with entity-framework should be similiar.

aogan
links appear to be out of date?
Jeff Atwood
links fixed, post edited - it's ony applicable in MVC. thanks Jeff
Shimmy
+1  A: 

In .NET 4, there is going to be out-the-box validation support in Entity-Framework.

Check out: http://blogs.msdn.com/adonet/archive/2010/01/13/introducing-the-portable-extensible-metadata.aspx

So don't work to hard on implementing too complex validation logic...

Shimmy
Oddly, the PEM extension and its samples are, for some reason, no longer available via MSDN. I'd love an updated link if anyone has one!
ladenedge
I hope they're not fooling us...I guess I was wrong saying out-the-box, I now realize that it's just an addon.It says that the addon can be downloaded from http://visualstudiogallery.msdn.microsoft.com/en-us/e6467914-d48d-4075-8885-ce5a0dcb744dbut check out the link to see that it's broken.
Shimmy
Shimmy
A: 

This article describes how to integrate Validation Application Block with Entity Framework. It might be of some help.

Steven
A: 

If you are using WPF or Windows Forms then you might implement the IDataErrorInfo interface.

The BookLibrary sample application of the WPF Application Framework (WAF) project shows how entities created by the Entity Framework can be validated.

jbe