DataTable Class
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Represents one table of in-memory data.
public ref class DataTable : System::ComponentModel::MarshalByValueComponent, System::ComponentModel::IListSource, System::ComponentModel::ISupportInitialize, System::ComponentModel::ISupportInitializeNotification, System::Runtime::Serialization::ISerializable, System::Xml::Serialization::IXmlSerializable
public ref class DataTable
public ref class DataTable : System::ComponentModel::MarshalByValueComponent, System::ComponentModel::IListSource, System::ComponentModel::ISupportInitialize, System::Runtime::Serialization::ISerializable
public ref class DataTable : System::ComponentModel::MarshalByValueComponent, System::ComponentModel::IListSource, System::ComponentModel::ISupportInitializeNotification, System::Runtime::Serialization::ISerializable, System::Xml::Serialization::IXmlSerializable
public class DataTable : System.ComponentModel.MarshalByValueComponent, System.ComponentModel.IListSource, System.ComponentModel.ISupportInitialize, System.ComponentModel.ISupportInitializeNotification, System.Runtime.Serialization.ISerializable, System.Xml.Serialization.IXmlSerializable
public class DataTable
[System.Serializable]
public class DataTable : System.ComponentModel.MarshalByValueComponent, System.ComponentModel.IListSource, System.ComponentModel.ISupportInitialize, System.Runtime.Serialization.ISerializable
[System.Serializable]
public class DataTable : System.ComponentModel.MarshalByValueComponent, System.ComponentModel.IListSource, System.ComponentModel.ISupportInitializeNotification, System.Runtime.Serialization.ISerializable, System.Xml.Serialization.IXmlSerializable
public class DataTable : System.ComponentModel.MarshalByValueComponent, System.ComponentModel.IListSource, System.ComponentModel.ISupportInitializeNotification, System.Runtime.Serialization.ISerializable, System.Xml.Serialization.IXmlSerializable
type DataTable = class
inherit MarshalByValueComponent
interface IListSource
interface ISupportInitialize
interface ISupportInitializeNotification
interface ISerializable
interface IXmlSerializable
type DataTable = class
[<System.Serializable>]
type DataTable = class
inherit MarshalByValueComponent
interface IListSource
interface ISupportInitialize
interface ISerializable
[<System.Serializable>]
type DataTable = class
inherit MarshalByValueComponent
interface IListSource
interface ISupportInitializeNotification
interface ISupportInitialize
interface ISerializable
interface IXmlSerializable
Public Class DataTable
Inherits MarshalByValueComponent
Implements IListSource, ISerializable, ISupportInitialize, ISupportInitializeNotification, IXmlSerializable
Public Class DataTable
Public Class DataTable
Inherits MarshalByValueComponent
Implements IListSource, ISerializable, ISupportInitialize
Public Class DataTable
Inherits MarshalByValueComponent
Implements IListSource, ISerializable, ISupportInitializeNotification, IXmlSerializable
- Inheritance
- Inheritance
-
DataTable
- Derived
- Attributes
- Implements
The following example creates two DataTable objects and one DataRelation object, and adds the new objects to a DataSet. The tables are then displayed in a DataGridView control.
// Put the next line into the Declarations section.
private System.Data.DataSet dataSet;
private void MakeDataTables()
{
// Run all of the functions.
MakeParentTable();
MakeChildTable();
MakeDataRelation();
BindToDataGrid();
}
private void MakeParentTable()
{
// Create a new DataTable.
System.Data.DataTable table = new DataTable("ParentTable");
// Declare variables for DataColumn and DataRow objects.
DataColumn column;
DataRow row;
// Create new DataColumn, set DataType,
// ColumnName and add to DataTable.
column = new DataColumn();
column.DataType = System.Type.GetType("System.Int32");
column.ColumnName = "id";
column.ReadOnly = true;
column.Unique = true;
// Add the Column to the DataColumnCollection.
table.Columns.Add(column);
// Create second column.
column = new DataColumn();
column.DataType = System.Type.GetType("System.String");
column.ColumnName = "ParentItem";
column.AutoIncrement = false;
column.Caption = "ParentItem";
column.ReadOnly = false;
column.Unique = false;
// Add the column to the table.
table.Columns.Add(column);
// Make the ID column the primary key column.
DataColumn[] PrimaryKeyColumns = new DataColumn[1];
PrimaryKeyColumns[0] = table.Columns["id"];
table.PrimaryKey = PrimaryKeyColumns;
// Instantiate the DataSet variable.
dataSet = new DataSet();
// Add the new DataTable to the DataSet.
dataSet.Tables.Add(table);
// Create three new DataRow objects and add
// them to the DataTable
for (int i = 0; i <= 2; i++)
{
row = table.NewRow();
row["id"] = i;
row["ParentItem"] = "ParentItem " + i;
table.Rows.Add(row);
}
}
private void MakeChildTable()
{
// Create a new DataTable.
DataTable table = new DataTable("childTable");
DataColumn column;
DataRow row;
// Create first column and add to the DataTable.
column = new DataColumn();
column.DataType = System.Type.GetType("System.Int32");
column.ColumnName = "ChildID";
column.AutoIncrement = true;
column.Caption = "ID";
column.ReadOnly = true;
column.Unique = true;
// Add the column to the DataColumnCollection.
table.Columns.Add(column);
// Create second column.
column = new DataColumn();
column.DataType = System.Type.GetType("System.String");
column.ColumnName = "ChildItem";
column.AutoIncrement = false;
column.Caption = "ChildItem";
column.ReadOnly = false;
column.Unique = false;
table.Columns.Add(column);
// Create third column.
column = new DataColumn();
column.DataType = System.Type.GetType("System.Int32");
column.ColumnName = "ParentID";
column.AutoIncrement = false;
column.Caption = "ParentID";
column.ReadOnly = false;
column.Unique = false;
table.Columns.Add(column);
dataSet.Tables.Add(table);
// Create three sets of DataRow objects,
// five rows each, and add to DataTable.
for (int i = 0; i <= 4; i++)
{
row = table.NewRow();
row["childID"] = i;
row["ChildItem"] = "Item " + i;
row["ParentID"] = 0;
table.Rows.Add(row);
}
for (int i = 0; i <= 4; i++)
{
row = table.NewRow();
row["childID"] = i + 5;
row["ChildItem"] = "Item " + i;
row["ParentID"] = 1;
table.Rows.Add(row);
}
for (int i = 0; i <= 4; i++)
{
row = table.NewRow();
row["childID"] = i + 10;
row["ChildItem"] = "Item " + i;
row["ParentID"] = 2;
table.Rows.Add(row);
}
}
private void MakeDataRelation()
{
// DataRelation requires two DataColumn
// (parent and child) and a name.
DataColumn parentColumn =
dataSet.Tables["ParentTable"].Columns["id"];
DataColumn childColumn =
dataSet.Tables["ChildTable"].Columns["ParentID"];
DataRelation relation = new
DataRelation("parent2Child", parentColumn, childColumn);
dataSet.Tables["ChildTable"].ParentRelations.Add(relation);
}
private void BindToDataGrid()
{
// Instruct the DataGrid to bind to the DataSet, with the
// ParentTable as the topmost DataTable.
DataGrid1.SetDataBinding(dataSet, "ParentTable");
}
' Put the next line into the Declarations section.
private dataSet As DataSet
Private Sub MakeDataTables()
' Run all of the functions.
MakeParentTable()
MakeChildTable()
MakeDataRelation()
BindToDataGrid()
End Sub
Private Sub MakeParentTable()
' Create a new DataTable.
Dim table As New DataTable("ParentTable")
' Declare variables for DataColumn and DataRow objects.
Dim column As DataColumn
Dim row As DataRow
' Create new DataColumn, set DataType, ColumnName
' and add to DataTable.
column = New DataColumn()
column.DataType = System.Type.GetType("System.Int32")
column.ColumnName = "id"
column.ReadOnly = True
column.Unique = True
' Add the Column to the DataColumnCollection.
table.Columns.Add(column)
' Create second column.
column = New DataColumn()
column.DataType = System.Type.GetType("System.String")
column.ColumnName = "ParentItem"
column.AutoIncrement = False
column.Caption = "ParentItem"
column.ReadOnly = False
column.Unique = False
' Add the column to the table.
table.Columns.Add(column)
' Make the ID column the primary key column.
Dim PrimaryKeyColumns(0) As DataColumn
PrimaryKeyColumns(0)= table.Columns("id")
table.PrimaryKey = PrimaryKeyColumns
' Instantiate the DataSet variable.
dataSet = New DataSet()
' Add the new DataTable to the DataSet.
dataSet.Tables.Add(table)
' Create three new DataRow objects and add
' them to the DataTable
Dim i As Integer
For i = 0 to 2
row = table.NewRow()
row("id") = i
row("ParentItem") = "ParentItem " + i.ToString()
table.Rows.Add(row)
Next i
End Sub
Private Sub MakeChildTable()
' Create a new DataTable.
Dim table As New DataTable("childTable")
Dim column As DataColumn
Dim row As DataRow
' Create first column and add to the DataTable.
column = New DataColumn()
column.DataType= System.Type.GetType("System.Int32")
column.ColumnName = "ChildID"
column.AutoIncrement = True
column.Caption = "ID"
column.ReadOnly = True
column.Unique = True
' Add the column to the DataColumnCollection.
table.Columns.Add(column)
' Create second column.
column = New DataColumn()
column.DataType= System.Type.GetType("System.String")
column.ColumnName = "ChildItem"
column.AutoIncrement = False
column.Caption = "ChildItem"
column.ReadOnly = False
column.Unique = False
table.Columns.Add(column)
' Create third column.
column = New DataColumn()
column.DataType= System.Type.GetType("System.Int32")
column.ColumnName = "ParentID"
column.AutoIncrement = False
column.Caption = "ParentID"
column.ReadOnly = False
column.Unique = False
table.Columns.Add(column)
dataSet.Tables.Add(table)
' Create three sets of DataRow objects, five rows each,
' and add to DataTable.
Dim i As Integer
For i = 0 to 4
row = table.NewRow()
row("childID") = i
row("ChildItem") = "Item " + i.ToString()
row("ParentID") = 0
table.Rows.Add(row)
Next i
For i = 0 to 4
row = table.NewRow()
row("childID") = i + 5
row("ChildItem") = "Item " + i.ToString()
row("ParentID") = 1
table.Rows.Add(row)
Next i
For i = 0 to 4
row = table.NewRow()
row("childID") = i + 10
row("ChildItem") = "Item " + i.ToString()
row("ParentID") = 2
table.Rows.Add(row)
Next i
End Sub
Private Sub MakeDataRelation()
' DataRelation requires two DataColumn
' (parent and child) and a name.
Dim parentColumn As DataColumn = _
dataSet.Tables("ParentTable").Columns("id")
Dim childColumn As DataColumn = _
dataSet.Tables("ChildTable").Columns("ParentID")
Dim relation As DataRelation = new _
DataRelation("parent2Child", parentColumn, childColumn)
dataSet.Tables("ChildTable").ParentRelations.Add(relation)
End Sub
Private Sub BindToDataGrid()
' Instruct the DataGrid to bind to the DataSet, with the
' ParentTable as the topmost DataTable.
DataGrid1.SetDataBinding(dataSet,"ParentTable")
End Sub
For more information about this API, see Supplemental API remarks for DataTable.
Data |
Initializes a new instance of the DataTable class with no arguments. |
Data |
Obsolete.
Initializes a new instance of the DataTable class with serialized data. |
Data |
Initializes a new instance of the DataTable class using the specified table name and namespace. |
Data |
Initializes a new instance of the DataTable class with the specified table name. |
f |
Checks whether initialization is in progress. The initialization occurs at run time. |
Case |
Indicates whether string comparisons within the table are case-sensitive. |
Child |
Gets the collection of child relations for this DataTable. |
Columns |
Gets the collection of columns that belong to this table. |
Constraints |
Gets the collection of constraints maintained by this table. |
Container |
Gets the container for the component. (Inherited from MarshalByValueComponent) |
Data |
Gets the DataSet to which this table belongs. |
Default |
Gets a customized view of the table that may include a filtered view, or a cursor position. |
Design |
Gets a value indicating whether the component is currently in design mode. (Inherited from MarshalByValueComponent) |
Display |
Gets or sets the expression that returns a value used to represent this table in the user interface. The |
Events |
Gets the list of event handlers that are attached to this component. (Inherited from MarshalByValueComponent) |
Extended |
Gets the collection of customized user information. |
Has |
Gets a value indicating whether there are errors in any of the rows in any of the tables of the DataSet to which the table belongs. |
Is |
Gets a value that indicates whether the DataTable is initialized. |
Locale |
Gets or sets the locale information used to compare strings within the table. |
Minimum |
Gets or sets the initial starting size for this table. |
Namespace |
Gets or sets the namespace for the XML representation of the data stored in the DataTable. |
Parent |
Gets the collection of parent relations for this DataTable. |
Prefix |
Gets or sets the namespace for the XML representation of the data stored in the DataTable. |
Primary |
Gets or sets an array of columns that function as primary keys for the data table. |
Remoting |
Gets or sets the serialization format. |
Rows |
Gets the collection of rows that belong to this table. |
Site | |
Table |
Gets or sets the name of the DataTable. |
Accept |
Commits all the changes made to this table since the last time AcceptChanges() was called. |
Begin |
Begins the initialization of a DataTable that is used on a form or used by another component. The initialization occurs at run time. |
Begin |
Turns off notifications, index maintenance, and constraints while loading data. |
Clear() |
Clears the DataTable of all data. |
Clone() |
Clones the structure of the DataTable, including all DataTable schemas and constraints. |
Compute(String, String) |
Computes the given expression on the current rows that pass the filter criteria. |
Copy() |
Copies both the structure and data for this DataTable. |
Create |
Returns a DataTableReader corresponding to the data within this DataTable. |
Create |
Creates a new instance of DataTable. |
Dispose() |
Releases all resources used by the MarshalByValueComponent. (Inherited from MarshalByValueComponent) |
Dispose(Boolean) |
Releases the unmanaged resources used by the MarshalByValueComponent and optionally releases the managed resources. (Inherited from MarshalByValueComponent) |
End |
Ends the initialization of a DataTable that is used on a form or used by another component. The initialization occurs at run time. |
End |
Turns on notifications, index maintenance, and constraints after loading data. |
Equals(Object) |
Determines whether the specified object is equal to the current object. (Inherited from Object) |
Get |
Gets a copy of the DataTable that contains all changes made to it since it was loaded or AcceptChanges() was last called. |
Get |
Gets a copy of the DataTable containing all changes made to it since it was last loaded, or since AcceptChanges() was called, filtered by DataRowState. |
Get |
This method returns an XmlSchemaSet instance containing the Web Services Description Language (WSDL) that describes the DataTable for Web Services. |
Get |
Gets an array of DataRow objects that contain errors. |
Get |
Serves as the default hash function. (Inherited from Object) |
Get |
Obsolete.
Populates a serialization information object with the data needed to serialize the DataTable. |
Get |
Gets the row type. |
Get |
For a description of this member, see GetSchema(). |
Get |
Gets the implementer of the IServiceProvider. (Inherited from MarshalByValueComponent) |
Get |
Gets the Type of the current instance. (Inherited from Object) |
Import |
Copies a DataRow into a DataTable, preserving any property settings, as well as original and current values. |
Load(IData |
Fills a DataTable with values from a data source using the supplied IDataReader using an error-handling delegate. |
Load(IData |
Fills a DataTable with values from a data source using the supplied IDataReader. If the |
Load(IData |
Fills a DataTable with values from a data source using the supplied IDataReader. If the DataTable already contains rows, the incoming data from the data source is merged with the existing rows. |
Load |
Finds and updates a specific row. If no matching row is found, a new row is created using the given values. |
Load |
Finds and updates a specific row. If no matching row is found, a new row is created using the given values. |
Memberwise |
Creates a shallow copy of the current Object. (Inherited from Object) |
Merge(Data |
Merge the specified DataTable with the current |
Merge(Data |
Merge the specified DataTable with the current |
Merge(Data |
|
New |
Creates a new DataRow with the same schema as the table. |
New |
Returns an array of DataRow. |
New |
Creates a new row from an existing row. |
On |
Raises the ColumnChanged event. |
On |
Raises the ColumnChanging event. |
On |
Raises the PropertyChanged event. |
On |
Notifies the DataTable that a DataColumn is being removed. |
On |
Raises the RowChanged event. |
On |
Raises the RowChanging event. |
On |
Raises the RowDeleted event. |
On |
Raises the RowDeleting event. |
On |
Raises the TableCleared event. |
On |
Raises the TableClearing event. |
On |
Raises the TableNewRow event. |
Read |
Reads XML schema and data into the DataTable using the specified Stream. |
Read |
Reads XML schema and data into the DataTable from the specified file. |
Read |
Reads XML schema and data into the DataTable using the specified TextReader. |
Read |
Reads XML Schema and Data into the DataTable using the specified XmlReader. |
Read |
Reads an XML schema into the DataTable using the specified stream. |
Read |
Reads an XML schema into the DataTable from the specified file. |
Read |
Reads an XML schema into the DataTable using the specified TextReader. |
Read |
Reads an XML schema into the DataTable using the specified XmlReader. |
Read |
Reads from an XML stream. |
Reject |
Rolls back all changes that have been made to the table since it was loaded, or the last time AcceptChanges() was called. |
Reset() |
Resets the DataTable to its original state. Reset removes all data, indexes, relations, and columns of the table. If a DataSet includes a DataTable, the table will still be part of the DataSet after the table is reset. |
Select() |
Gets an array of all DataRow objects. |
Select(String, String, Data |
Gets an array of all DataRow objects that match the filter in the order of the sort that match the specified state. |
Select(String, String) |
Gets an array of all DataRow objects that match the filter criteria, in the specified sort order. |
Select(String) |
Gets an array of all DataRow objects that match the filter criteria. |
To |
Gets the TableName and DisplayExpression, if there is one as a concatenated string. |
To |
Returns a string that represents the current object. (Inherited from Object) |
Write |
Writes the current contents of the DataTable as XML using the specified Stream. To save the data for the table and all its descendants, set the |
Write |
Writes the current data, and optionally the schema, for the DataTable to the specified file using the specified XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current data, and optionally the schema, for the DataTable to the specified file using the specified XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current contents of the DataTable as XML using the specified Stream. |
Write |
Writes the current contents of the DataTable as XML using the specified file. To save the data for the table and all its descendants, set the |
Write |
Writes the current data, and optionally the schema, for the DataTable using the specified file and XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current data, and optionally the schema, for the DataTable using the specified file and XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current contents of the DataTable as XML using the specified file. |
Write |
Writes the current contents of the DataTable as XML using the specified TextWriter. To save the data for the table and all its descendants, set the |
Write |
Writes the current data, and optionally the schema, for the DataTable using the specified TextWriter and XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current data, and optionally the schema, for the DataTable using the specified TextWriter and XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current contents of the DataTable as XML using the specified TextWriter. |
Write |
Writes the current contents of the DataTable as XML using the specified XmlWriter. |
Write |
Writes the current data, and optionally the schema, for the DataTable using the specified XmlWriter and XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current data, and optionally the schema, for the DataTable using the specified XmlWriter and XmlWriteMode. To write the schema, set the value for the |
Write |
Writes the current contents of the DataTable as XML using the specified XmlWriter. |
Write |
Writes the current data structure of the DataTable as an XML schema to the specified stream. To save the schema for the table and all its descendants, set the |
Write |
Writes the current data structure of the DataTable as an XML schema to the specified stream. |
Write |
Writes the current data structure of the DataTable as an XML schema to the specified file. To save the schema for the table and all its descendants, set the |
Write |
Writes the current data structure of the DataTable as an XML schema to the specified file. |
Write |
Writes the current data structure of the DataTable as an XML schema using the specified TextWriter. To save the schema for the table and all its descendants, set the |
Write |
Writes the current data structure of the DataTable as an XML schema using the specified TextWriter. |
Write |
Writes the current data structure of the DataTable as an XML schema using the specified XmlWriter. To save the schema for the table and all its descendants, set the |
Write |
Writes the current data structure of the DataTable as an XML schema using the specified XmlWriter. |
Column |
Occurs after a value has been changed for the specified DataColumn in a DataRow. |
Column |
Occurs when a value is being changed for the specified DataColumn in a DataRow. |
Disposed |
Adds an event handler to listen to the Disposed event on the component. (Inherited from MarshalByValueComponent) |
Initialized |
Occurs after the DataTable is initialized. |
Row |
Occurs after a DataRow has been changed successfully. |
Row |
Occurs when a DataRow is changing. |
Row |
Occurs after a row in the table has been deleted. |
Row |
Occurs before a row in the table is about to be deleted. |
Table |
Occurs after a DataTable is cleared. |
Table |
Occurs when a DataTable is cleared. |
Table |
Occurs when a new DataRow is inserted. |
IList |
For a description of this member, see ContainsListCollection. |
IList |
For a description of this member, see GetList(). |
ISerializable. |
Populates a serialization information object with the data needed to serialize the DataTable. |
IXml |
For a description of this member, see GetSchema(). |
IXml |
For a description of this member, see ReadXml(XmlReader). |
IXml |
For a description of this member, see WriteXml(XmlWriter). |
As |
Creates and returns a LINQ-enabled DataView object. |
As |
Returns an IEnumerable<T> object, where the generic parameter |
Product | Versions |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9 |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 2.0, 2.1 |
This type is safe for multithreaded read operations. You must synchronize any write operations.
.NET feedback
.NET is an open source project. Select a link to provide feedback: