c# – 从EF作为字典返回2列,Id和count
发布时间:2020-12-15 23:30:51 所属栏目:百科 来源:网络整理
导读:我在两个表之间有一个FK关系,但是为了这个查询的目的,我需要得到每个FK的行数. 例如,我有CareTaker表和CareTakerId作为PK;和CareTakerId作为FK的Animal表.鉴于CareTakerIds列表,我想要每个看护者负责的所有AnimalIds.像这样的东西: select CareTakerId,coun
我在两个表之间有一个FK关系,但是为了这个查询的目的,我需要得到每个FK的行数.
例如,我有CareTaker表和CareTakerId作为PK;和CareTakerId作为FK的Animal表.鉴于CareTakerIds列表,我想要每个看护者负责的所有AnimalIds.像这样的东西: select CareTakerId,count(1) from Animal where CareTakerId in (1,2,3,4) and AnimalTypeId = 3 group by CareTakerId 哪个回报 CareTakerId | No ColumnName 1 | 42 2 | 6 我如何在EntityFramework中执行此操作? query .Where(r => r.AnimalTypeId == animalTypeId && careTakerIds.Contains(r => r.CareTakerId)) .GroupBy(r => r.CareTakerId) // Not sure what to write here; r.CareTakerId doesn't exist .Select(r => new {r.key,r.value }) .ToDictionary(kvp => kvp.Key,kvp => kvp.value); 如何在实体框架中选择CareTakerId和count(1)? 解决方法
你非常接近,只需添加“Count()”方法.
query .Where(r => r.AnimalTypeId == animalTypeId && careTakerIds.Contains(r => r.CareTakerId)) .GroupBy(r => r.CareTakerId) .Select(r => new {r.key,value = r.Count() }) .ToDictionary(kvp => kvp.Key,kvp => kvp.value); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |