• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > asp.net DataTable相关操作集锦(筛选,取前N条数据,去重复行,获取指定列数据等)

asp.net DataTable相关操作集锦(筛选,取前N条数据,去重复行,获取指定列数据等)

作者:smartsmile2012 字体:[增加 减小] 来源:互联网 时间:2017-05-11

smartsmile2012通过本文主要向大家介绍了asp.net DataTable相关操作集锦(筛选,取前N条数据,去重复行,获取指定列数据等)等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例总结了asp.net DataTable相关操作。分享给大家供大家参考,具体如下:

#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

</div>
#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

</div>
#region 获取DataTable中指定列的数据
/// <summary>
/// 获取DataTable中指定列的数据
/// </summary>
/// <param name="dt">数据源</param>
/// <param name="tableName">新的DataTable的名词</param>
/// <param name="strColumns">指定的列名集合</param>
/// <returns>返回新的DataTable</returns>
public static DataTable GetTableColumn(DataTable dt, string tableName, params string[] strColumns)
{
  DataTable dtn = new DataTable();
  if (dt == null)
  {
    throw new ArgumentNullException("参数dt不能为null");
  }
  try
  {
    dtn = dt.DefaultView.ToTable(tableName, true, strColumns);
  }
  catch (Exception e)
  {
    throw new Exception(e.Message);
  }
  return dtn;
}
#endregion

</div>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Data;
using System.Collections;
using System.Text;
namespace GuanEasy
{
 /// <summary>
  /// DataSet助手
  /// </summary>
  public class DataSetHelper
  {
    private class FieldInfo
    {
      public string RelationName;
      public string FieldName;
      public string FieldAlias;
      public string Aggregate;
    }
    private DataSet ds;
    private ArrayList m_FieldInfo;
    private string m_FieldList;
    private ArrayList GroupByFieldInfo;
    private string GroupByFieldList;
    public DataSet DataSet
    {
      get { return ds; }
    }
    #region Construction
    public DataSetHelper()
    {
      ds = null;
    }
    public DataSetHelper(ref DataSet dataSet)
    {
      ds = dataSet;
    }
    #endregion
    #region Private Methods
    private bool ColumnEqual(object objectA, object objectB)
    {
      if ( objectA == DBNull.Value && objectB == DBNull.Value )
      {
        return true;
      }
      if ( objectA == DBNull.Value || objectB == DBNull.Value )
      {
        return false;
      }
      return ( objectA.Equals( objectB ) );
    }
    private bool RowEqual(DataRow rowA, DataRow rowB, DataColumnCollection columns)
    {
      bool result = true;
      for ( int i = 0; i < columns.Count; i++ )
      {
        result &= ColumnEqual( rowA[ columns[ i ].ColumnName ], rowB[ columns[ i ].ColumnName ] );
      }
      return result;
    }
    private void ParseFieldList(string fieldList, bool allowRelation)
    {
      if ( m_FieldList == fieldList )
      {
        return;
      }
      m_FieldInfo = new ArrayList();
      m_FieldList = fieldList;
      FieldInfo Field;
      string[] FieldParts;
      string[] Fields = fieldList.Split( ',' );
      for ( int i = 0; i <= Fields.Length - 1; i++ )
      {
        Field = new FieldInfo();
        FieldParts = Fields[ i ].Trim().Split( ' ' );
        switch ( FieldParts.Length )
        {
          case 1:
            //to be set at the end of the loop
            break;
          case 2:
            Field.FieldAlias = FieldParts[ 1 ];
            break;
          default:
            return;
        }
        FieldParts = FieldParts[ 0 ].Split( '.' );
        switch ( FieldParts.Length )
        {
          case 1:
            Field.FieldName = FieldParts[ 0 ];
            break;
          case 2:
            if ( allowRelation == false )
            {
              return;
            }
            Field.RelationName = FieldParts[ 0 ].Trim();
            Field.FieldName = FieldParts[ 1 ].Trim();
            break;
          default:
            return;
        }
        if ( Field.FieldAlias == null )
        {
          Field.FieldAlias = Field.FieldName;
        }
        m_FieldInfo.Add( Field );
      }
    }
    private DataTable CreateTable(string tableName, DataTable sourceTable, string fieldList)
    {
      DataTable dt;
      if ( fieldList.Trim() == "" )
      {
        dt = sourceTable.Clone();
        dt.TableName = tableName;
      }
      else
      {
        dt = new DataTable( tableName );
        ParseFieldList( fieldList, false );
        DataColumn dc;
        foreach ( FieldInfo Field in m_FieldInfo )
        {
          dc = sourceTable.Columns[ Field.FieldName ];
          DataColumn column = new DataColumn();
          column.ColumnName = Field.FieldAlias;
          column.DataType = dc.DataType;
          column.MaxLength = dc.MaxLength;
          column.Expression = dc.Expression;
          dt.Columns.Add( column );
        }
      }
      if ( ds != null )
      {
        ds.Tables.Add( dt );
      }
      return dt;
    }
    private void InsertInto(DataTable destTable, DataTable sourceTable,
                string fieldList, string rowFilter, string sort)
    {
      ParseFieldList( fieldList, false );
      DataRow[] rows = sourceTable.Select( rowFilter, sort );
      DataRow destRow;
      foreach ( DataRow sourceRow in rows )
      {
        destRow = destTable.NewRow();
        if ( fieldList == "" )
        {
          foreach ( DataColumn dc in destRow.Table.Columns )
          {
            if ( dc.Expression == "" )
            {
              destRow[ dc ] = sourceRow[ dc.ColumnName ];
            }
          }
        }
        else
        {
          foreach ( FieldInfo field in m_FieldInfo )
          {
            destRow[ field.FieldAlias ] = sourceRow[ field.FieldName ];
          }
        }
        destTable.Rows.Add( destRow );
      }
    }
    private void ParseGroupByFieldList(string FieldList)
    {
      if ( GroupByFieldList == FieldList )
      {
        return;
      }
      GroupByFieldInfo = new ArrayList();
      FieldInfo Field;
      string[] FieldParts;
      string[] Fields = FieldList.Split( ',' );
   



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • asp.net DataTable相关操作集锦(筛选,取前N条数据,去重复行,获取指定列数据等)

相关文章

  • 2017-05-11ASP.NET Table 表格控件的使用方法
  • 2017-05-11asp.net中JavaScript数据验证实现代码
  • 2017-05-11C#中常用的分页存储过程小结
  • 2017-05-11asp.net中如何实现水印
  • 2017-05-11Visual Studio 2017安装心得总结
  • 2017-05-11ASP.NET中用js取CheckBoxList中值的方法实例
  • 2017-05-11使用C#处理WebBrowser控件在不同域名中的跨域问题
  • 2017-05-11基于ASP.NET+EasyUI框架实现图片上传提交表单功能(js提交图片)
  • 2017-05-11GridView中加上CheckBox 的全选功能的代码
  • 2017-05-11Linux下部署.net core环境的步骤详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • asp.net 用户控件读取以及赋值
    • asp.net core分块上传文件示例
    • ASP.Net下载大文件的实现方法
    • Asp.Net Core 通过中间件防止图片盗链的实例
    • .net 操作xml的简单方法及说明
    • System.Web中不存在类型或命名空间名称“Optimization”(是否缺少程序集引用?)
    • C#实现上传照片到物理路径,并且将地址保存到数据库的小例子
    • 详解在.net中读写config文件的各种方法
    • ASP.NET输入文本框自动提示功能
    • DataTable类Clone方法与Copy方法的区别分析

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有