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;必须自动通知会员&#xff0c;Java的API为我们提供了Observer接口和Observable类来实现所谓观察者模式。Observable(可观察者)类允许在自身发生改变时&#xff0c;通知其它对象(实现接口Observer&#xff0c;观察者)。下面是…

(剑指Offer)面试题5:从尾到头打印链表

题目&#xff1a; 输入一个链表的头结点&#xff0c;从尾到头反过来打印每个结点的值。 链表结点定义&#xff1a; struct ListNode{int value;ListNode* pNext; }; 思路&#xff1a; 1、改变链表结构的话&#xff0c;先反转链表&#xff0c;然后从头到尾打印每个结点的值。&am…

java解析json数组对象_JAVA中快速解析JSON对象里包含的JSON数组

例如现在有这样一个JsonString Value {"data":[{"school_name":"西北农林科技大学","school_id":"8"},{"school_name":"西北大学","school_id":"6"},{"school_name":&…

ACM water

1000 纯属适应题 1003 做的时候花了很久&#xff0c;现在看好像也不难 1004 适应题&#xff0c;求下平均就行 1005 要读懂题就行 1007 逆序数&#xff0c;discuss方法 1046 全部暴搜一遍。。 1118 照抄2606没看题。。WA。。RE全占了 1207 貌似我的方法超级麻烦 1247 …

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

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

openoffice转换过程中遇到繁体字文档转换失败的问题

今天发现上线的文档转换功能中存在一个文档转换不成功&#xff0c;查看后台日志标志文档无法加载成功&#xff0c;提示日志如下&#xff1a; INFO: connected Jul 08, 2015 2:50:33 PM com.artofsolving.jodconverter.openoffice.connection.AbstractOpenOfficeConnection conn…

java导出excel文件名_怎么解决java导出excel时文件名乱码

怎么解决java导出excel时文件名乱码发布时间&#xff1a;2020-06-19 16:59:00来源&#xff1a;亿速云阅读&#xff1a;137作者&#xff1a;元一java解决导出Excel时文件名乱码的方法示例&#xff1a;String agent request.getHeader("USER-AGENT").toLowerCase();re…

error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MDd_DynamicDebug”不匹配值“MTd_StaticDebug”...

今日VS2012 C编译出现一堆错误: 1 1> 正在生成代码...2 1>Code.obj : error LNK2005: "public: __thiscall std::_Container_base12::_Container_base12(void)" (??0_Container_base12stdQAEXZ) 已经在 msvcprtd.lib(MSVCP110D.dll) 中定义3 1>Code.obj …

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

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

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

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

Eclips将lib打入war中

在项目的属性&#xff0c; java build path -> Libraries -> Add library.. -> Web app Libraries 。即可。 在属性中&#xff0c; Deployment Assembly ->add -> project 或者 java build path entries. 这个是一半jar到处。对于WAR 没用。 Eclipse中关于JRE S…

file相对路径java_浅谈java 中文件的读取File、以及相对路径的问题

一、对于java项目中文件的读取1、使用system 或是 系统的properties对象①直接是使用 string relativelypathsystem.getproperty("user.dir");②使用properties对象我们先来遍历一下系统的属性&#xff1a;properties properties system.getproperties();enumeratio…

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> <!-- 需要…