Trying to do a left join in subsonic using linq but it doesn't seem to work, I get a big error.
I'm pretty sure the query is correct as I've done it a few times with objects and Linq2Sql.
var post = from p in Post.All()
join q in Quote.All() on p.ID equals q.PostID into pq
where p.ID == id.Value
from qt in pq.DefaultIfEmpty()
select new {p, qt};
It just seems subsonic isn't able to generate the required SQL from left join linq queries.
Am I doing something wrong here? Is there a work around?
Update: I'm using subsonic 3.0.0.2 here is the error I get when I try a left join with subsonic
Expression of type 'System.Collections.Generic.IEnumerable1[GetAQuote.Post]' cannot be used for parameter of type 'System.Linq.IQueryable
1[GetAQuote.Post]' of method 'System.Linq.IQueryable1[<>f__AnonymousType2
2[GetAQuote.Post,System.Collections.Generic.IEnumerable1[GetAQuote.Quote]]] GroupJoin[Post,Quote,Int32,<>f__AnonymousType2
2](System.Linq.IQueryable1[GetAQuote.Post], System.Collections.Generic.IEnumerable
1[GetAQuote.Quote], System.Linq.Expressions.Expression1[System.Func
2[GetAQuote.Post,System.Int32]], System.Linq.Expressions.Expression1[System.Func
2[GetAQuote.Quote,System.Int32]], System.Linq.Expressions.Expression1[System.Func
3[GetAQuote.Post,System.Collections.Generic.IEnumerable1[GetAQuote.Quote],<>f__AnonymousType2
2[GetAQuote.Post,System.Collections.Generic.IEnumerable`1[GetAQuote.Quote]]]])'