创建数据表

DataTable 表示一个内存内关系数据的表,可以独立创建和使用,也可以由其他 .NET Framework 对象使用,最常见的情况是作为 DataSet 的成员使用。

可以使用相应的 DataTable 构造函数创建 DataTable 对象。 可以通过使用 Add 方法将其添加到 DataSet 对象的 Tables 集合中,从而将其添加到数据集中。

也可以通过以下方法创建 DataTable 对象:使用 DataAdapter 对象的 Fill 方法或 FillSchema 方法在数据集中创建,或者使用数据集的 ReadXml、ReadXmlSchema 或 InferXmlSchema 方法从预定义的或推断的 XML 架构中创建。 请注意,将一个 DataTable 作为成员添加到一个数据集的 Tables 集合中后,不能再将其添加到任何其他数据集的表集合中。

初次创建 DataTable 时,是没有架构(即结构)的。 要定义表的架构,必须创建 DataColumn 对象并将其添加到表的 Columns 集合中。 也可以为表定义主键列,并且可以创建 Constraint 对象并将其添加到表的 Constraints 集合中。 在为 DataTable 定义了架构之后,可通过将 DataRow 对象添加到表的 Rows 集合中来将数据行添加到表中。

创建 DataTable 时,不需要为 TableName 属性提供值,你可以在其他时间指定该属性,或者将其保留为空。 但是,在将一个没有 TableName 值的表添加到数据集中时,该表会得到一个从“Table”(表示 Table0)开始递增的默认名称 TableN。

备注

建议在提供 TableName 值时避免使用“TableN”命名约定,因为那样提供的名称可能与数据集中现有的默认表名冲突。 如果提供的名称已经存在,将引发异常。

以下示例创建 DataTable 对象的实例,并为其指定名称“Customers”。

Dim workTable as DataTable = New DataTable("Customers")  
DataTable workTable = new DataTable("Customers");  

以下示例创建 DataTable 实例,方法是:将其添加到数据集的 Tables 集合中。

Dim customers As DataSet = New DataSet  
Dim customersTable As DataTable = _  
   customers.Tables.Add("CustomersTable")  
DataSet customers = new DataSet();  
DataTable customersTable = customers.Tables.Add("CustomersTable");  

请参阅