如何使用Nhibernate进行条件求和
本文关键字:条件 求和 何使用 Nhibernate | 更新日期: 2023-09-27 18:28:12
我正在尝试执行与此SQL代码等效的操作
SELECT
ID
SUM(CASE WHEN myProperty = 2 THEN 1 ELSE 0 END) as nbRowWithValueOf2,
SUM(CASE WHEN myProperty = 3 THEN 1 ELSE 0 END) as nbRowWithValueOf3
FROM Foo
GROUP BY ID
使用Nhibernate。
到目前为止,我尝试了
queryable = queryable
.Select(
Projections.Group<Foo>(c => c.ID),
Projections.Sum<Foo>(c => c.myProperty == MyEnum.Two ? 1 : 0)
Projections.Sum<Foo>(c => c.myProperty == MyEnum.Three ? 1 : 0)
)
但这给了我以下错误:
无法从IIF((Convert(c.myProperty)=2),1,0)中确定成员
你知道吗?
编辑1:我可以用2个查询得到结果,但我只想在1个查询中做到这一点。
编辑2:我在这里使用QueryOver。
我认为这应该有效(QueryOver语法):
queryover = queryover
.Select(
Projections.Group<Foo>(c => c.ID),
Projections.Sum(
Projections.Conditional(
Restrictions.Where<Foo>(f => f.myProperty == MyEnum.Two),
Projections.Constant(1),
Projections.Constant(0))),
Projections.Sum(
Projections.Conditional(
Restrictions.Where<Foo>(f => f.myProperty == MyEnum.Three),
Projections.Constant(1),
Projections.Constant(0))));
它应该为您提供以下SQL:
SELECT this_.ID as y0_,
sum((case
when this_.myProperty = 2 /* @p0 */ then 1 /* @p1 */
else 0 /* @p2 */
end)) as y1_,
sum((case
when this_.myProperty = 3 /* @p3 */ then 1 /* @p4 */
else 0 /* @p5 */
end)) as y2_
FROM [Foo] this_
GROUP BY this_.ID