zoukankan      html  css  js  c++  java
  • DataTable 操作集合

     

    #region 根据datatable获得列名     public static string[] GetColumnsByDataTable(DataTable dt)
            /// <summary>
            /// 根据datatable获得列名
           /// </summary>
            /// <param name="dt">表对象</param>
            /// <returns>返回结果的数据列数组</returns>
            public static string[] GetColumnsByDataTable(DataTable dt)
            {
                string[] strColumns = null;
    
    
                if (dt.Columns.Count > 0)
                {
                    int columnNum = 0;
                    columnNum = dt.Columns.Count;
                    strColumns = new string[columnNum];
                    for (int i = 0; i < dt.Columns.Count; i++)
                    {
                        strColumns[i] = dt.Columns[i].ColumnName;
                    }
                }
    
    
                return strColumns;
            } 
            #endregion 
     

    把datatable的结构全部数据或部分数据复制到一个新的datatable
    datatable复制表结构:我们可以使用.clone()方法;
      DataTable oldDT = GetDataTable();
      DataTable newDT = oldDT.Clone();


      把datatable中的所有信息复制到一个新的datatable,包括结构和数据:
      DataTable oldDT = GetDataTable();
      DataTable newDT = oldDT.Copy();


      复制datatable中的某一行:我们可以使用.ImportRow()方法;
      DataTable oldDT = GetDataTable();
      DataTable newDT = new DataTable();
      newDT.ImportRow(oldDT.Rows[1]);把原来datatable中的第二行数据复制到新的datatable中。

    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;

    namespace DataTableGroupDemo
    {
    class Program
    {
    static void Main(string[] args)
    {
    // 准备数据
    DataTable dt = new DataTable();
    // 创建列
    DataColumn dcName = new DataColumn("Name", typeof(string));
    DataColumn dcAge = new DataColumn("Age", typeof(Int32));
    DataColumn dcScore = new DataColumn("Score", typeof(Int32));
    // 添加列
    dt.Columns.Add(dcName);
    dt.Columns.Add(dcAge);
    dt.Columns.Add(dcScore);
    // 添加数据
    dt.Rows.Add(new object[] { "Tom", 23, 67 });
    dt.Rows.Add(new object[] { "Tom", 23, 67 });
    dt.Rows.Add(new object[] { "Jack", 21, 100 });
    dt.Rows.Add(new object[] { "Greey", 24, 56 });
    dt.Rows.Add(new object[] { "Kevin", 24, 77 });
    dt.Rows.Add(new object[] { "Tom", 23, 82 });
    dt.Rows.Add(new object[] { "Greey", 24, 80 });
    dt.Rows.Add(new object[] { "Jack", 21, 90 });


    #region 使用Linq expression to DataTable group by
    var query = from p in dt.AsEnumerable()
    group p by new { name = p.Field<string>("Name"),score=p.Field<Int32>("Score") } into m
    select new
    {
    Name = m.Key.name,
    Score=m.Key.score
    };
    #endregion

    // 输出
    Console.WriteLine("Linq");
    foreach (var item in query)
    {
    Console.WriteLine(item);
    }

    Console.WriteLine("GroupBy");
    IEnumerable<IGrouping<string, DataRow>> result = dt.Rows.Cast<DataRow>().GroupBy<DataRow, string>(dr => dr["Name"].ToString());
    foreach (IGrouping<string, DataRow> ig in result)
    {
    Console.WriteLine("key=" + ig.Key + ":");
    foreach (DataRow dr in ig)
    {
    Console.WriteLine(dr["Name"].ToString().PadRight(10) + dr["Age"].ToString().PadRight(10) + dr["Score"].ToString().PadRight(10));
    }

    }

    Console.ReadKey();
    }
    }
    }

  • 相关阅读:
    MySQL调优篇 | 逻辑架构解读(1)
    SQLPlus 在连接时通常有四种方式
    Oracle解决索引碎片功能
    windows2003 ftp 无法下载 解决
    bat记录
    ACCESS字符串操作函数
    缓存和RAID如何提高磁盘IO性能
    TortoiseSVN 命令 (命令行执行工具)
    在RHEL5下实现磁盘分区和磁盘配额
    PS 命令详解
  • 原文地址:https://www.cnblogs.com/liangyuwen/p/13274260.html
Copyright © 2011-2022 走看看