DataTable操作

DataTable操作

一 复制DataTable中符合条件的DataRow到新的DataTable中

 

  One:

DataTable TableTemp = new DataTable();//临时table
DataTable tableAd = new Web.DAL.FreeBase().TranSQLGetTable("select a.ClassName,b.ParentId,b.Name,b.Pic,b.Url,b.Sorts from AdClass a inner join Ad b on a.Id=b.ParentId");//查询的结果if (tableAd != null && tableAd.Rows.Count > 0){Tableflag = tableAd.Copy();//复制结构Tableflag.Clear();//清除临时数据foreach (DataRow dr in tableAd.Rows){if (dr["ParentId"].ToString().Equals("17")){DataRow tempRow =TableTemp.NewRow(); //创建与该表相同架构的新行
              tempRow["ClassName"] = dr["ClassName"];
              tempRow["ParentId"] = dr["ParentId"];
              tempRow["Name"] = dr["Name"];
              tempRow["Pic"] = dr["Pic"];
              tempRow["Url"] = dr["Url"];
              tempRow["Sorts"] = dr["Sorts"];
              TableTemp.Rows.Add(tempRow);
            }
          }
        }

Two:

#region DataTable筛选,排序返回符合条件行组成的新DataTable或直接用DefaultView按条件返回/// <summary>  /// DataTable筛选,排序返回符合条件行组成的新DataTable或直接用DefaultView按条件返回  /// eg:SortExprDataTable(dt,"Sex='男'","Time Desc",1)  /// </summary>  /// <param name="dt">传入的DataTable</param>  /// <param name="strExpr">筛选条件</param>  /// <param name="strSort">排序条件</param>  /// <param name="mode">1,直接用DefaultView按条件返回,效率较高;2,DataTable筛选,排序返回符合条件行组成的新DataTable</param>  public static DataTable SortDataTable(DataTable dt, string strExpr, string strSort, int mode){switch (mode){case 1://方法一 直接用DefaultView按条件返回  dt.DefaultView.RowFilter = strExpr;dt.DefaultView.Sort = strSort;return dt;case 2://方法二 DataTable筛选,排序返回符合条件行组成的新DataTable  DataTable dt1 = new DataTable();DataRow[] GetRows = dt.Select(strExpr, strSort);//复制DataTable dt结构不包含数据  dt1 = dt.Clone();foreach (DataRow row in GetRows){dt1.Rows.Add(row.ItemArray);}return dt1;default:return dt;}}#endregion  
View Code
//选取ParentId=17的所以行,并根据Sorts降序排序
TableTemp = SortDataTable(tableAd, "ParentId=17", "Sorts Desc", 2);

Three:

        #region 获取DataTable前几条数据/// <summary>  /// 获取DataTable前几条数据  /// </summary>  /// <param name="TopItem">前N条数据</param>  /// <param name="oDT">源DataTable</param>  /// <returns></returns>  public static DataTable DtSelectTop(int TopItem, DataTable oDT){if (oDT.Rows.Count < TopItem) return oDT;DataTable NewTable = oDT.Clone();DataRow[] rows = oDT.Select("1=1");for (int i = 0; i < TopItem; i++){NewTable.ImportRow((DataRow)rows[i]);}return NewTable;}#endregion
View Code

 

//选取前7行数据
TableTemp = DtSelectTop(7, Table1);

 

posted on 2015-07-03 14:43 无影飞絮剑 阅读(...) 评论(...) 编辑 收藏

转载于:https://www.cnblogs.com/itslives-com/p/4618627.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/419780.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java水印图片_JAVA实用案例之图片水印开发

写在最前面上周零零碎碎花了一周的时间研究水印的开发&#xff0c;现在终于写了个入门级的Demo&#xff0c;做下笔记同时分享出来供大家参考。Demo是在我上次写的 JAVA实用案例之文件导入导出(POI方式) 框架基础上搭建的&#xff0c;基于SpringSpringMVC。如果有错误还请大家指…

adreno630gpu参数_adreno630gpu参数_高通骁龙430参数性能 Adreno505 GPU/20nm制程

高通最新骁龙430八核处理器曝光&#xff0c;具体型号为MSM8937&#xff0c;那么这颗高通骁龙430 MSM8937八核处理器参数和性能表现如何&#xff0c;跑分多少呢&#xff0c;本文带来相关规格的解析。9月15日&#xff0c;高通对外发布了最新低端处理器骁龙430和中端处理器骁龙617…

前端学习(1537):为什么使用ng

传统输入页面值1 传统加法运算

C#开发Unity游戏教程之判断语句

C#开发Unity游戏教程之判断语句 游戏执行路径的选择——判断 玩家在游戏时&#xff0c;无时无刻不在通过判断做出选择。例如&#xff0c;正是因为玩家做出的选择不同&#xff0c;才导致游戏朝着不同的剧情发展&#xff0c;因此一个玩家可以对一个游戏百玩不厌&#xff01;既然提…

前端学习(1539):hello world

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </head> <!-- 需要…

Android Sdk 国内镜像下载地址

大连东软信息学院镜像服务器地址:- http://mirrors.neusoft.edu.cn 端口&#xff1a;80北京化工大学镜像服务器地址:- IPv4: http://ubuntu.buct.edu.cn/ 端口&#xff1a;80- IPv4: http://ubuntu.buct.cn/ 端口&#xff1a;80- IPv6: http://ubuntu.buct6.edu.cn/ 端口&#…

java手机飞行模式_用了这么多年手机才知道,飞行模式还藏着这6个功能!太好用了...

说起“飞行模式”很多朋友们都会说我又不坐飞机&#xff0c;要它有啥用&#xff1f;当然有用&#xff01;而且用处可多了不纠结手机辐射问题很多朋友担心晚上不关机手机会有辐射&#xff0c;但是又觉得关机开机很繁琐&#xff0c;真是很纠结。其实只要把手机飞行模式打开就行啦…

前端学习(1545):模型和控制器

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </head> <!-- 需要…

java是不是饱和了_广州Java难学吗?Java是不是已经饱和了

无论是在校的学生也好&#xff0c;还是转行的也好&#xff0c;如今学Java开发的人越来越多&#xff0c;造成了如今新手越来越多&#xff0c;有人说前端饱和了&#xff0c;Java饱和了&#xff0c;Java才刚开始以一种好的势头发展就饱和了&#xff1f;怎么可能&#xff0c;一般说…