I would like to translate the following SQL into LINQ:
SELECT
(Select count(BidID)) as TotalBidNum,
(Select sum(Amount)) as TotalBidVal
FROM Bids
I've tried this:
from b in _dataContext.Bids
select new { TotalBidVal = b.Sum(p => p.Amount), TotalBidNum = b.Count(p => p.BidId) }
but get an error "Bids does not contain a definition for "Sum" and no extension method "Sum" accepting a first argument of type "Bids" could be found.
How can I do this in LINQ?
Thanks
CONCLUDING:
The final answer was:
var ctx = _dataContext.Bids;
var itemsBid = (from b in _dataContext.Bids
select new { TotalBidVal = ctx.Sum(p => p.Amount), TotalBidNum = ctx.Count() }).First();
You could do it using the Aggregate Clause.
If you're using Fx4+ or an extension dll for Fx2, you could also benfit from parallelism by using
here's an alternative to scartag's solution:
Although there's no real reason you can't just say:
It hits the database twice, but its very readable
You could try this out. The variable b is an entity (for every iteration) while ctx is an entityset which has the extension methods you need.
You can write this query using
GroupBy
. The Lambda expression is as follows: