如何将我在此查询中对 [Confirmed / Total] 字段所做的操作转换为 lambda?与铸造

How to translate what I do with the [Confirmed / Total] field in this query to lambda? with CAST

我正在尝试获取所有已确认事件的用户,以下查询显示了它的外观

select us.ServiceId, s.Image, s.Title, s.CreatedTimestamp, (cast(count(us.Answer) as varchar(10))) + 
'/' + (cast((select count(Id) from Users) as varchar(10))) [Confirmed / Total]
from Services s inner join UserServices us on s.Id = us.ServiceId
where us.ServiceId = '5cf37da7-e7ba-4652-8526-96b3ad19fd13'
group by us.ServiceId, s.Image, s.Title, s.CreatedTimestamp

结果:

但是我只能得到已经确认的用户,我也想得到用户总数。

我做了一个包含最多字段的 lambda,除了用户总数:

Services.Join(UserServices, s => s.Id, us => us.ServiceId, (s, us) => new { s,us })
.Where(w => (w.us.ServiceId == "5cf37da7-e7ba-4652-8526-96b3ad19fd13"))
.GroupBy(gb => new  
     {
        ServiceId = gb.us.ServiceId, 
        Image = gb.s.Image, 
        Title = gb.s.Title, 
        CreatedTimestamp = gb.s.CreatedTimestamp,
        ConfirmedTotal = gb.us.Answer
     }, gb => new { us = gb.us, s = gb.s })
.Select(sl => new  
     {
        ServiceId = sl.Key.ServiceId, 
        Image = sl.Key.Image, 
        Title = sl.Key.Title, 
        CreatedTimestamp = sl.Key.CreatedTimestamp,
        ConfirmedTotal = sl.Count(x => x.us.Answer)
     })

结果:

那么,如何翻译或有什么方法可以做到这一点?

我尝试了这个并且成功了:

Services.Join(UserServices, s => s.Id, us => us.ServiceId, (s, us) => new { s,us })
.Where(w => (w.s.ServiceTypeId == "efb6fd56-45be-4402-a960-ed93bcbeea79"))
.GroupBy(gb => new  
     {
        ServiceTypeId = gb.us.ServiceId, 
        Image = gb.s.Image, 
        Title = gb.s.Title, 
        CreatedTimestamp = gb.s.CreatedTimestamp,
        ConfirmedTotal = string.Concat(gb.us.Answer.ToString(), " / ", db.Users.Select(s => s.Id).Count().ToString())
})
.Select(s => new  
     {
        ServiceId = s.Key.ServiceTypeId, 
        Image = s.Key.Image, 
        Title = s.Key.Title, 
        CreatedTimestamp = s.Key.CreatedTimestamp,
        ConfirmedTotal = string.Concat(s.Count(x => x.us.Answer).ToString(), " / ", db.Users.Select(s2 => s2.Id).Count().ToString())
     })