一、思维导图
二、知识点描述
(1)构造函数
DataTable() | 不带参数初始化DataTable类的新实例 |
DataTable(string tableName) | 用指定的表名初始化DataTable类的新实例 |
DataTable(string tableName, string tableNamespace) | 用指定的表名和命名空间初始化DataTable类的新实例 |
(2) 常用属性
CaseSensitive | 指示表中的字符串比较是否区分大小写 |
ChildRelations | 获取此DataTable的子关系的集合 |
Columns | 获取属于该表的列的集合 |
Constraints | 获取由该表维护的约束的集合 |
DataSet | 获取此表所属的DataSet |
DefaultView | 获取可能包括筛选视图或游标位置的表的自定义视图 |
HasErrors | 获取一个值,该值指示该表所属的DataSet的任何表的任何行中是否有错误 |
MinimumCapacity | 获取或设置该表最初的起始大小。该表中行的最初起始大小。默认值为 50。 |
Rows | 获取属于该表的行的集合 |
TableName | 获取或设置DataTable的名称 |
(3)常用方法
AcceptChanges() | 提交自上次调用AcceptChanges()以来对该表进行的所有更改 |
RejectChanges() | 方法被调用时,仍处于编辑模式的任何行将取消其编辑。新行被移除。已修改的和已删除的行返回到其原始状态(DataRowState.Unchanged) |
GetChanges() | 获取DataTable 的副本,该副本包含自上次加载以来或自调用AcceptChanges 以来对该数据集进行的所有更改。 |
BeginInit() | 开始初始化在窗体上使用或由另一个组件使用的DataTable。初始化发生在运行时 |
Clear() | 清除所有数据的DataTable |
Clone() | 克隆DataTable的结构,包括所有DataTable架构和约束 |
Copy() | 复制,具有与该 DataTable相同的结构(表架构和约束)和数据。 注意如果这些类已经过派生,则副本也具有相同的派生类 |
EndInit() | 结束在窗体上使用或由另一个组件使用的DataTable的初始化。初始化发生在运行时 |
ImportRow(DataRow row) | 将DataRow复制到DataTable中,保留任何属性设置以及初始值和当前值。 |
Merge(DataTable table) | 将指定的DataTable与当前的DataTable合并 合并操作仅对原始表和要合并的表进行操作。子表不会受到影响或被包括在内。如果某个表具有一个或多个作为关系的一部分定义的子表,则需要分别合并每个子表 |
NewRow() | 创建与该表具有相同架构的新DataRow |
三、示例代码
添加引用
using System.Data;
创建表
DataTable dt = new DataTable();//创建一个空表
DataTable dt = new DataTable("Table_New");
创建列
//1.创建空列
DataColumn dc = new DataColumn();
dt.Columns.Add(dc);
//2.创建带列名和类型名的列(两种方式任选其一)
dt.Columns.Add("column0", System.Type.GetType("System.String"));
dt.Columns.Add("column0", typeof(String));
//3.通过列架构添加列
DataColumn dc = new DataColumn("column1",System.Type.GetType("System.DateTime"));
DataColumn dc = new DataColumn("column1", typeof(DateTime));
dt.Columns.Add(dc);
创建行
//1.创建空行
DataRow dr = dt.NewRow();
dt.Rows.Add(dr);
//2.创建空行
dt.Rows.Add();
//3.通过行框架创建并赋值
dt.Rows.Add("张三",DateTime.Now);//Add里面参数的数据顺序要和dt中的列的顺序对应
//4.通过复制dt2表的某一行来创建
dt.Rows.Add(dt2.Rows[i].ItemArray);
赋值和取值
//新建行的赋值
DataRow dr = dt.NewRow();
dr[] = "张三";//通过索引赋值
dr["column1"] = DateTime.Now; //通过名称赋值
//对表已有行进行赋值
dt.Rows[][] = "张三"; //通过索引赋值
dt.Rows[]["column1"] = DateTime.Now;//通过名称赋值
//取值
string name=dt.Rows[][].ToString();
string time=dt.Rows[]["column1"].ToString();
筛选行
//选择column1列值为空的行的集合
DataRow[] drs = dt.Select("column1 is null");
//选择column0列值为"李四"的行的集合
DataRow[] drs = dt.Select("column0 = '李四'");
//筛选column0列值中有"张"的行的集合(模糊查询)
DataRow[] drs = dt.Select("column0 like '张%'");//如果的多条件筛选,可以加 and 或 or
//筛选column0列值中有"张"的行的集合并按column1降序排序
DataRow[] drs = dt.Select("column0 like '张%'", "column1 DESC");
删除行
//使用DataTable.Rows.Remove(DataRow)方法
dt.Rows.Remove(dt.Rows[]);
//使用DataTable.Rows.RemoveAt(index)方法
dt.Rows.RemoveAt();
//使用DataRow.Delete()方法
dt.Row[].Delete();
dt.AcceptChanges(); //-----区别和注意点-----
//Remove()和RemoveAt()方法是直接删除
//Delete()方法只是将该行标记为deleted,但是还存在,还可DataTable.RejectChanges()回滚,使该行取消删除。
//用Rows.Count来获取行数时,还是删除之前的行数,需要使用DataTable.AcceptChanges()方法来提交修改。
//如果要删除DataTable中的多行,应该采用倒序循环DataTable.Rows,而且不能用foreach进行循环删除,因为正序删除时索引会发生变化,程式发生异常,很难预料后果。
for (int i = dt.Rows.Count - ; i >= ; i--)
{
dt.Rows.RemoveAt(i);
}
复制表
//复制表,同时复制了表结构和表中的数据
DataTable dtNew = new DataTable();
dtNew = dt.Copy();
//复制表
DataTable dtNew = dt.Copy(); //复制dt表数据结构
dtNew.Clear() //清空数据
for (int i = ; i < dt.Rows.Count; i++)
{
if (条件语句)
{
dtNew.Rows.Add(dt.Rows[i].ItemArray); //添加数据行
}
}
//克隆表,只是复制了表结构,不包括数据
DataTable dtNew = new DataTable();
dtNew = dt.Clone();
//如果只需要某个表中的某一行
DataTable dtNew = new DataTable();
dtNew = dt.Copy();
dtNew.Rows.Clear();//清空表数据
dtNew.ImportRow(dt.Rows[]);//这是加入的是第一行
表排序
DataTable dt = new DataTable();//创建表
dt.Columns.Add("ID", typeof(Int32));//添加列
dt.Columns.Add("Name", typeof(String));
dt.Columns.Add("Age", typeof(Int32));
dt.Rows.Add(new object[] { , "张三" ,});//添加行
dt.Rows.Add(new object[] { , "李四" ,});
dt.Rows.Add(new object[] { , "王五" ,});
DataView dv = dt.DefaultView;//获取表视图
dv.Sort = "ID DESC";//按照ID倒序排序
dv.ToTable();//转为表
四、效果截图