引用

using System.Data;

创建DataTable

DataTable dt = new DataTable();
//指定表明,当把这个table添加到dataset时你就可以用dataset.table["tablename"]取到这个表对象
//如果不写的话,在dataset中取这个表的时候只能通过索引来取 也就是0,1,2...这种形式来取
DataTable dt =new DataTable("员工信息");

  

给DataTable增加两列

dt.Columns.Add("员工年龄");
dt.Columns.Add("员工姓名");//默认存或取datatable里的数据都是obj类型。存的时候可以加限制,该列只能存什么类型的数据,实际上还是obj
//或者
dt.Columns.Add("员工年龄", typeof(int));
dt.Columns.Add("员工姓名", typeof(string));
 

给DataTable增加行(有列才能加入行数据)

//创建和表dt相同架构的一行
DataRow dr1 = dt.NewRow();  
dr1["员工年龄"] = 28;        
dr1["员工姓名"] = "沈腾";
dt.Rows.Add(dr1); //把该行存进dt      //或者用索引的方式加入数据
DataRow dr2 = dt.NewRow();  
dr2[0] = 32;
dr2[1] = "马丽";
dt.Rows.Add(dr2);
//遍历打印dt数据
for (int x = 0; x < dt.Columns.Count; x++)
{
for (int y = 0; y < dt.Rows.Count; y++)
{
string strName = dt.Rows[x][y].ToString();
Console.WriteLine(strName);
}
}
Console.ReadKey();

或者

foreach (DataRow row in dt.Rows)
{
  foreach (DataColumn column in dt.Columns)
  {
    Console.WriteLine(row[column]);
  }
}
Console.ReadKey()

属性及属性的方法:

//设置表名
dt.TableName = "员工信息";

 

dt.Columns是DataColumnCollection 类

//获得列名集合
DataColumnCollection dc = dt.Columns;
// 检查集合是否包含具有指定名称的列,返回布尔值
bool f = dt.Columns.Contains("员工年龄");
//返回该列索引
int a = dt.Columns.IndexOf("员工姓名");
//删除该列
dt.Columns.Remove("员工姓名");
//删除索引所在的列
dt.Columns.RemoveAt(0);
string str1 = Convert.ToString(dt.Columns["员工年龄"]);
string str2 = Convert.ToString(dt.Columns[1]);
Console.WriteLine(str1+str2);

结果:

//在末尾增加一列
dt.Columns.Add("员工住址");

dt.Rows是DataRowCollection类

//第一行第二列
dt.Rows[0][1].ToString();
//获取此行的所有值,返回object类型
 dt.Rows.Add(dt.Rows[0].ItemArray);
//插入1行数据 --没测过
dt.Rows.InsertAt(dr, 1);

datatable方法:

//清空表中的数据,但结构还在
dt.Clear();
//插入一行数据
dt.ImportRow(dr2);
DataTable dt2 = new DataTable("员工信息2");
//克隆表的结构
dt2 = dt.Clone();
//克隆表的结构并且复制表的数据
dt2 = dt.Copy();
//把dt2合并到dt1,相同列名数据合并,不同列名单独一列
dt1.Merge(dt2);
//获得表名
string str = dt.ToString();
//统计列数
dt.Columns.Count;

dt.Select() ---给datatable排序

//返回DataRow对象数组
DataRow[] rows = dt.Select();
for (int i = 0; i < rows.Length; i++)
{
  Console.WriteLine(rows[i]["员工年龄"]);
}

Select(String)

//支持and
Select("员工年龄>=18 and 员工年龄<=35");
//支持or //支持like
Select("员工姓名 like '沈%' or 员工姓名 like '马%'");

Select(String, String)

//参数2 排序
DataRow[] dr = dt.Select("员工年龄>5", "员工年龄 desc");

xml转DataTable

//将 XML 架构和数据读入 DataTable 使用指定 Stream
ReadXml(Stream);
//将 XML 架构和数据读入 DataTable 从指定的文件
ReadXml(String);
//读取 XML 架构到 DataTable 使用指定的流
ReadXmlSchema(Stream);
//读取 XML 架构到 DataTable 从指定的文件
ReadXmlSchema(String);
//Stream 可以替换成 String类型、TextWriter类型、XmlWriter类型
WriteXml(Stream)
//
WriteXml(Stream, Boolean)
//
WriteXml(Stream, XmlWriteMode)
//
WriteXml(Stream, XmlWriteMode, Boolean)
//Stream 可以替换成 String类型、TextWriter类型、XmlWriter类型
WriteXmlSchema(Stream)
//
WriteXmlSchema(Stream, Boolean)

(4)DataTable的更多相关文章

  1. DataTable 转换成 Json的3种方法

    在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>.DataTable转换为Json格式.特别在使用Extjs框架的时候,A ...

  2. C#中将DataTable导出为HTML的方法

    今天我要向大家分享一种将DataTable导出为到HTML格式的方法.有时我们需要HTML格式的输出数据, 以下代码就可以帮助我们达到目的,. 首先,我们要绑定DataTable和 DataGridV ...

  3. DataTable转换成IList<T>的简单实现

    DataTable的无奈 很多时候,我们需要去操作DataTable.但DataTable的操作,实在是太不方便了.Linq?lambda表达式?统统没有... 特别是对现有结果集做进一步筛选,这样的 ...

  4. 自用的基于Emit的C#下DataTable转实体类方法

    之前一直在做WebForm的开发,数据绑定时直接DataTable绑定Gridview很方便,但是最近开始往MVC转,数据列表的传递和页面展示基本上是以List为主,像下面这样,遍历实体类的各个字段去 ...

  5. jquery dataTable汉化(插件形式)

    1.jquery dataTable.js 官网:http://datatables.net/ 中文:http://dt.thxopen.com/ 2.汉化提示信息(放到xx.js中,引入即可) 注: ...

  6. DataTable与DTO对象的简易转换类

    在web开发过程中,有时候为了数据传输的方便,比如:后台需要更新前端的ViewModel,此时我们定义一个与前端ViewModel结构一样的DTO对象,从数据层获取数据后,将数据封装成DTO然后序列化 ...

  7. asp.net DataTable导出Excel 自定义列名

    1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...

  8. asp.net dataTable转换成Json格式

    /// <summary> /// dataTable转换成Json格式 /// </summary> /// <param name="dt"> ...

  9. DataTable的orderby有关问题

    在网上找了一个在后台重新对DataTable排序的方法(之所以不在数据库是因为我生成的是报表,写了存储过程用的表变量,order by也要用变量,死活拼不起来,sql能力没过关,动态sql也试了) s ...

  10. 关于c#在DataTable中根据条件删除某一行

    我们经常会将数据源放在DataTable里面,但是有时候也需要移除不想要的行,下面的代码告诉你们 DataTable dts:                DataRow[] foundRow;   ...

随机推荐

  1. DC课程目标

  2. python爬虫基础18-Chrome调试前端工具

    01 Chrome调试 抓包工具原理 Chrome 开发者工具是一套内置在Google Chrome中Web开发和调试工具.使用开发者工具来重演,调试和剖析您的网站. 其中常用的有Elements(元 ...

  3. Python之路--序列化

    序列化的目的 1.以某种存储形式使自定义对象持久化 2.将对象从一个地方传递到另一个地方 3.使程序更具有维护性 json json多语言通用 四个功能:dumps.dump.loads.load # ...

  4. Java并发编程的艺术 记录(四)

    Java线程的状态: new :初始状态,但是还没调用start方法. runnable:运行状态. blocked:阻塞状态. waiting:等待状态,表示当前线程需要等待其他线程作出一些特定动作 ...

  5. Divisibility by 25 CodeForces - 988E

    You are given an integer nn from 11 to 10181018 without leading zeroes. In one move you can swap any ...

  6. HDU 5371 Manacher Hotaru's problem

    求出一个连续子序列,这个子序列由三部分ABC构成,其中AB是回文串,A和C相同,也就是BC也是回文串. 求这样一个最长的子序列. Manacher算法是在所有两个相邻数字之间插入一个特殊的数字,比如- ...

  7. 大数据学习——KETTLE入门学习——kettle安装

    https://blog.csdn.net/u012637358/article/details/82593492 下载的kettle是汉化的 改成英文的 工具——选项——选择英文

  8. python_字符串,元组,格式化输出

    一.字符串 1.字符串是有成对的单引号或者双引号括起来的.例如:name="张三",sex="女" 2.字符串的索引是从0开始的 3.字符串的切片 a.单个字符 ...

  9. Python全栈开发第二期课表

     day01-python 全栈开发-基础篇                 01 开课介绍 01:55:13 ★  02 开课介绍02 01:28:31 ★  03 开课介绍03 00:22:55 ...

  10. 03-python进阶-爬虫入门-正则

    [urllib and urllib2] 这是两个python的网络模块 内置的 提供很好的网络访问的功能. #!coding:utf-8 import urllib2 res = urllib2.u ...