With Entity Framework 4.3 and Linq, I want to match a search string against certain properties of contained objects and also on the properties of child objects. This turns out to be a rather complex query though, and I’m not sure how to do it. For instance, one property is an integer and I’m not allowed to call .ToString() in a Linq query.
In order to give you an idea of what I’m trying to do, consider this example code:
var dbVersions = from ver in db.Versions
where ver.Name.Contains(search) ||
ver.Children.Any(c=>c.Id.ToString().Contains(search))
select ver;
How should I implement this search? Perhaps via a stored procedure?
The database server is SQL Server 2012.
If you want to use LINQ the framework internally will do the proper optimizations and from my experience the results are quite OK.
If you don’t want to use an stored procedure and stick to LINQ keeping it all in your class code use:
for converting your int to an string. Note that there is no overload for int, so you need to cast it to double or decimal.