C#中Datatable的Compute的用法(转载)

        DataTable dt = new DataTable();

//嵌套的三元运算(iif判断) object obj = dt.Compute("iif(1000=5,1000,iif(100>100,4001,2000))", null); Response.Write(obj);//计算常量,可以没有初始化列 object test = table.Compute("1+1", ""); Console.WriteLine(test); //计算绝对值 test = table.Compute("abs(1)", ""); Console.WriteLine(test);

//求余数 test = table.Compute("2%2", ""); Console.WriteLine(test); //*************************************支持的聚合函数**********************// //求数量 test = table.Compute("count(id)", "false"); Console.WriteLine(test); //test=0; test = table.Compute("count(id)", "true"); Console.WriteLine(test); //test=10; //求和 test = table.Compute("sum(value)", ""); Console.WriteLine(test); //test=55; //test = table.Compute("sum(id)",""); /**/ ////抛出异常,这里不能是string //平均 test = table.Compute("avg(value)", ""); Console.WriteLine(test); //test=5; //最小 test = table.Compute("min(value)", ""); Console.WriteLine(test); //test=1; //最大 test = table.Compute("max(value)", ""); Console.WriteLine(test); //test=10; //统计标准偏差 test = table.Compute("StDev(value)", ""); Console.WriteLine(test); //test=3.02765035409749 //统计方差 test = table.Compute("Var(value)", ""); Console.WriteLine(test); //test=9.16666666666667 //复杂计算 test = table.Compute("max(value)/sum(value)", ""); Console.WriteLine(test); //test=0.181818181818182

/*******************************************计算列*************************/ System.Data.DataColumn column = new DataColumn("exp1", typeof(float)); table.Columns.Add(column); //简单计算 column.Expression = "value*2"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=2; //字符串函数 column.Expression = "len(id)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=3; //字符串函数 column.Expression = "len(' '+id+' ')"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=5; //字符串函数 column.Expression = "len(trim(' '+id+' '))"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=3; //字符串函数 column.Expression = "substring(id,3,len(id)-2)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=1; //substring的起始字符位置为1不是0 //类型转换 column.Expression = "convert(substring(id,3,len(id)-2),'System.Int32')*1.6"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=1.6; //相当于sqlserver的isnull column.Expression = "isnull(value,10)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=1; //三元运算符,相当于sqlserver的case when column.Expression = "iif(value>5,1000,2000)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=2000; //like运算符 column.Expression = "iif(id like '%1',1000,2000)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=1000; //in运算符 column.Expression = "iif(id not in('id1'),1000,2000)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=2000; //嵌套的三元运算 column.Expression = "iif(value>5,1000,iif(id like '%1',4000,2000))"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=4000; //客户端计算所占总数的百分比 column.Expression = "value/sum(value)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=0.01818182 //客户端计算差值,比如nba常规赛的胜场差 column.Expression = "max(value)-value"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=9 //***********************父子表计算*************************************/ //初始化子表,父子表关系 DataTable tableChild = new DataTable(); tableChild.Columns.Add("id", typeof(string)); tableChild.Columns.Add("value", typeof(int)); System.Data.DataSet ds = new DataSet(); ds.Tables.Add(tableChild); ds.Tables.Add(table); DataRelation relation = new DataRelation("relation", table.Columns["id"], tableChild.Columns["id"]); ds.Relations.Add(relation); for (int i = 1; i <= 10; i++) { System.Data.DataRow dRow = tableChild.NewRow(); dRow["id"] = "id1"; dRow["value"] = i; tableChild.Rows.Add(dRow); } //计算子表记录数 column.Expression = "count(child(relation).value)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=10; //计算父子表的百分比 column.Expression = "value/sum(child(relation).value)"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=0.01818182; //计算父子表的差值,比如父表为库存数量,子表为订购数量,计算得出需要补充的数量 column.Expression = "iif(value-sum(child(relation).value)>0,0,value-sum(child(relation).value))"; test = table.Select("id='id1'")[0]["exp1"]; Console.WriteLine(test); //test=-54; //比较遗憾的是没有发现能够计算同比和环比的方法,而且计算列无法作为约束 //结束,DataTable可以让你尽量发挥聪明才智来减少繁杂的sql语句并且减轻服务器计算符合

本文转载至:

转载于:https://www.cnblogs.com/firstjie333/p/4757673.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: C#DataTable.Select方法是用于从DataTable选择符合指定条件的行的方法。它的语法如下: DataTable.Select(string filterExpression, string sortExpression, DataViewRowState rowState) 其,filterExpression是用于筛选行的表达式,sortExpression是用于排序的表达式,rowState是用于指定行状态的枚举值。 例如,以下代码将从名为"myTable"的DataTable选择所有"Age"列大于等于18的行,并按照"Name"列升序排序: DataTable myTable = new DataTable(); // 假设myTable已经填充了数据 DataRow[] selectedRows = myTable.Select("Age >= 18", "Name ASC"); 这样,selectedRows数组就包含了符合条件的行。 ### 回答2: 我作为一名AI语言模型,对于"c"这个问题需要进一步的了解。根据上下文,我猜测可能是在讨论计算机科学的编程语言C。因此,我将围绕这个主题展开回答。 C是一种高级编程语言,最初由Dennis Ritchie于1972年在贝尔实验室开发。它在计算机科学和工程领域得到了广泛的应用,包括操作系统,编译器,数据库,游戏等等。C语言被称为高级语言,因为它比机器语言更易于编写和理解,同时又比其他高级语言(如Java、Python)更接近底层机器指令。 C语言的特点是灵活性强,运行速度快,可移植性好,所以在系统底层开发应用广泛。许多经典的操作系统(如Unix,Linux和Windows)和库都是用C语言编写的。此外,许多编程语言(如C++和Objective-C)都是在C语言的基础上开发的。 C语言也有一些缺点,例如它对程序员的要求非常高,需要精确的语法和细节,否则程序可能会出错。此外,C语言相对较底层,需要更多的代码实现与其他高级语言相比相同的功能。 总之,C语言在计算机科学的重要性不言而喻。尽管现在出现了许多其他优秀的编程语言,C语言在掌握系统底层编程,提高编程能力和理解计算机工作原理方面仍然是一个不可或缺的工具。 ### 回答3: 我很抱歉,但是您没有给出问题或提示,我无法提供具体的回答。如果您能提供更多信息,我将非常乐意为您提供帮助和支持。如果您需要任何其他帮助,请随时与我联系。谢谢!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值