国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C# DataTable中Compute方法用法集錦(數值/字符串/運算符/表等操作)

2019-10-29 21:26:43
字體:
來源:轉載
供稿:網友

本文實例講述了C# DataTable中Compute方法用法。分享給大家供大家參考,具體如下:

Compute函數的參數就兩個:Expression,和Filter。

Expresstion是計算表達式,關于Expression的詳細內容請看這里:

http://msdn2.microsoft.com/zh-cn/library/system.data.datacolumn.expression(VS.80).aspx

而Filter則是條件過濾器,類似sql的Where條件。

DataTable dt = new DataTable();//嵌套的三元運算 牛叉到五體投地object obj = dt.Compute("iif(1000=5,1000,iif(100>100,4001,2000))", null);Response.Write(obj);System.Data.DataTable table = new DataTable();//計算常量,可以沒有初始化列object test = table.Compute("1+1", "");Console.WriteLine(test);string a = "123";System.Double b = 123;decimal c = 123m;Console.WriteLine(Convert.ToDecimal(a));//test=2;test = table.Compute("1+1", "false");Console.WriteLine(test);//test=2;常數計算和filter無關test = table.Compute("abs(1)", "");Console.WriteLine(test);//test=null,不知道為什么這個沒有報錯,而且返回null,其他的數學函數都會抱錯test = table.Compute("2%2", "");Console.WriteLine(test);//test=0;//其他函數參考下面的計算列//初始化datataletable.Columns.Add("id", typeof(string));table.Columns.Add("value", typeof(int));for (int i = 1; i <= 10; i++){  System.Data.DataRow dRow = table.NewRow();  dRow["id"] = "id" + i.ToString();  dRow["value"] = i;  table.Rows.Add(dRow);}//test = table.Compute("value+1", "true");/**/////拋出異常,這里必須是聚合函數//*************************************支持的聚合函數**********************////求數量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的isnullcolumn.Expression = "isnull(value,10)";test = table.Select("id='id1'")[0]["exp1"];Console.WriteLine(test);//test=1;//三元運算符,相當于sqlserver的case whencolumn.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語句并且減輕服務器計算符合


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 邵武市| 吴川市| 枣阳市| 开化县| 高青县| 绥中县| 闽清县| 武邑县| 钦州市| 治多县| 吴川市| 辉县市| 长汀县| 虹口区| 阳山县| 府谷县| 腾冲县| 道孚县| 乌兰县| 宁国市| 同江市| 象州县| 敦煌市| 鄂托克前旗| 彰化县| 龙山县| 扶沟县| 永泰县| 巫山县| 台东县| 天长市| 吉首市| 西昌市| 峨眉山市| 嵊泗县| 定陶县| 新河县| 古丈县| 冷水江市| 棋牌| 新安县|