DataTable中Compute报错“聚合参数中的语法错误: 需要具有可能的“Child”限定符的单个列参数”

public Object Compute(
	string expression,string filter
)

参数

expression
类型: System.String
要计算的表达式。
filter
类型: System.String
要限制在表达式中进行计算的行的筛选器。
返回值 类型: System.Object
Object,设置为计算结果。 如果该表达式计算得出 Null,则返回值将为即为Value

使用DtaTable中的Compute函数报如下错误:

聚合参数中的语法错误: 需要具有可能的“Child”限定符的单个列参数。

解决办法:

expression参数里面的语法规则是要符合MSSQL的,比如有一个列名为“语言0-100”要进行汇总,写成“sum(语言0-100)”是会报上述错误的;应该写成符合MSSQL规范的SQL语句“sum([语言0-100])”,这样程序运行就通过了。这个语句中的中括号[]是关键所在。

相关文章

什么是设计模式一套被反复使用、多数人知晓的、经过分类编目...
单一职责原则定义(Single Responsibility Principle,SRP)...
动态代理和CGLib代理分不清吗,看看这篇文章,写的非常好,强...
适配器模式将一个类的接口转换成客户期望的另一个接口,使得...
策略模式定义了一系列算法族,并封装在类中,它们之间可以互...
设计模式讲的是如何编写可扩展、可维护、可读的高质量代码,...