ADO.NET Entity Framework Comparison Frustration
Today I began playing with the ADO.NET Entity Framework. This framework looks very promising and I plan on experimenting with it heavily this weekend, so expect some more ADOe articles over the next few weeks.
[Update: I discovered more about this subject while reading in-depth the MSDN articles on the ADO.NET Entity Framework. I have updated my conclusions at Entity Framework Comparison Frustration: Explained]
Without going into too much detail, ADOe is very similar to LINQ to SQL. It is essentially a more advanced OR/M that is built into the .NET framework and integrated heavily with Visual Studio designer support, complete with a few snap-in panes for visually mapping your database schema to your CLR objects. I found this post on MSDN explaining the major differences between LINQ to SQL and the ADO.NET Entity Framework.
Later I will go into much more detail about ADOe in general, but for now I wanted to bring up a problem I ran into tonight. My database schema is simple, I have a table called Teams, and a table called Accounts. Each Team has an OwnerId which relates to the AccountId of the Account table â every Team must have an owner. Lets try and get all Teams for a specific AccountâŚ
TorvusEntities entities = new TorvusEntities();
// Pull my Account Entity from the database
Account matt = entities.Accounts.First(a => a.AccountId == 10);
// Attempt to get all Teams by a Team Owner
var teams = from t in entities.Teams
where t.Owner == matt
select t;
Looks pretty simple right? The driving force behind ADOe is of course to abstract away data access, so that any .NET developer can read and understand the query intention even if he had never seen T-SQL before in his life. Well, apparently my query isnât acceptable. I am getting an exception:
Unable to create a constant value of type âClosure typeâ. Only primitive types (for instance Int32, String and Guid) are supported in this context.
Hmm, ok thatâs unfortunate. Google is turning up nothing interesting. Apparently the Entity framework can only query primitive types. So naturally I tried to compare the AccountId property instead of a direct instance-to-instance comparison â something that, IMHO, looks more like T-SQL than C#.
// This works, by comparing the AccountId (int) column
var teams = from t in entities.Teams
where t.Owner.AccountId == matt.AccountId
select t;
So I started thinking, maybe ADOe just needs to know how to compare two instances, letâs override some operators
public partial class Account
{
public static bool operator ==(Account a, Account b)
{
return a.AccountId == b.AccountId;
}
}
Damn, same exception. Well Iâm going to admit that this could very possibly be an error on my part, after all itâs 2 AM and I only installed ADOe Beta 3 a few hours ago⌠Iâll update if I discover anything.
Leave a Comment