这是我要评估的表达式:
Sum(IIF(QUALITY<=9.0,1.0,0.0))
问题是
string expr = "Sum(IIF(QUALITY<=9.0,1.0,0.0))";
dataTable.Compute(expr, "")
抛出一个错误说
Syntax error in aggregate argument: Expecting a single column argument with possible 'Child' qualifier.
主要的挑战是我不能手动重写表达式,因为它是从 RDL 文件中以字符串形式出现在我的程序中的,所以它最初看起来像
Sum(IIF(Fields!QUALITY.Value<=9.0,1.0,0.0))
并且我的程序需要自动将其转换为一个字符串,该字符串在传递给dataTable.Compute()
. 我从 Microsoft 的 Compute 方法文档中确定 C# 不喜欢“字段!” 或语法的“.Value”部分,通过删除它们,我可以使更简单的表达式正常工作;例如,这些语句都返回预期值:
dataTable.Compute("Sum(QUALITY)");
dataTable.Compute("Count(QUALITY)");
有可能做我想做的事吗?我觉得我应该只需要在某个地方稍微改变一下语法就可以了,但我无法在互联网上找到答案,这让我非常沮丧。
以下是我迄今为止尝试过的一些事情,但无济于事:
Sum(IIF([QUALITY]<=9.0,1.0,0.0))
Sum(Convert(IIF(QUALITY<=9.0,1.0,0.0), 'System.Double'))
Sum(IIF(Convert(QUALITY, 'System.Double')<=9.0,1.0,0.0))