DataTable クラス
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
メモリ内データの 1 つのテーブルを表します。
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
- 継承
- 継承
-
DataTable
- 派生
- 属性
- 実装
次の例では、2 つの DataTable オブジェクトと 1 つの DataRelation オブジェクトを作成し、新しいオブジェクトを に DataSet追加します。 その後、テーブルがコントロールに DataGridView 表示されます。
// 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
この API の詳細については、「 DataTable の補足 API 解説」を参照してください。
Data |
引数を指定せずに、DataTable クラスの新しいインスタンスを初期化します。 |
Data |
古い.
シリアル化したデータを使用して、DataTable クラスの新しいインスタンスを初期化します。 |
Data |
指定したテーブル名を使用して DataTable クラスの新しいインスタンスを初期化します。 |
Data |
指定したテーブル名と名前空間を使用して、DataTable クラスの新しいインスタンスを初期化します。 |
f |
初期化処理中かどうかをチェックします。 初期化は実行時に発生します。 |
Case |
テーブル内の文字列比較で大文字と小文字を区別するかどうかを示します。 |
Child |
この DataTable の子リレーションシップのコレクションを取得します。 |
Columns |
このテーブルに属する列のコレクションを取得します。 |
Constraints |
このテーブルに保持されている制約のコレクションを取得します。 |
Container |
コンポーネントを格納するコンテナーを取得します。 (継承元 MarshalByValueComponent) |
Data |
このテーブルが属する DataSet を取得します。 |
Default |
フィルター処理されたビューまたはカーソル位置を含むことがある、テーブルのカスタマイズされたビューを取得します。 |
Design |
コンポーネントが現在デザイン モードかどうかを示す値を取得します。 (継承元 MarshalByValueComponent) |
Display |
ユーザー インターフェイスにこのテーブルを表示するために使用する値を返す式を取得または設定します。
|
Events |
コンポーネントに結び付けられているイベント ハンドラーのリストを取得します。 (継承元 MarshalByValueComponent) |
Extended |
カスタマイズされたユーザー情報のコレクションを取得します。 |
Has |
テーブルが属する DataSet のいずれかのテーブルのいずれかの行にエラーがあるかどうかを示す値を取得します。 |
Is |
DataTable が初期化されているかどうかを示す値を取得します。 |
Locale |
テーブル内の文字列の比較に使用するロケール情報を取得または設定します。 |
Minimum |
このテーブルの初期開始サイズを取得または設定します。 |
Namespace |
DataTable に格納されているデータの XML 表現の名前空間を取得または設定します。 |
Parent |
この DataTable の親リレーションシップのコレクションを取得します。 |
Prefix |
DataTable に格納されているデータの XML 表現の名前空間を取得または設定します。 |
Primary |
このデータ テーブルの主キーとして機能する列の配列を取得または設定します。 |
Remoting |
シリアル化形式を取得または設定します。 |
Rows |
このテーブルに属する行のコレクションを取得します。 |
Site | |
Table |
DataTable の名前を取得または設定します。 |
Accept |
前回 AcceptChanges() を呼び出した以降にこのテーブルに対して行われたすべての変更をコミットします。 |
Begin |
フォームまたは別のコンポーネントで使用する DataTable の初期化を開始します。 初期化は実行時に発生します。 |
Begin |
データを読み込む間、通知、インデックスの維持、および制約をオフにします。 |
Clear() |
DataTable からすべてのデータを消去します。 |
Clone() | |
Compute(String, String) |
フィルター基準を満たしている現在の行で指定した式を計算します。 |
Copy() |
この DataTable の構造体だけでなくデータもコピーします。 |
Create |
この DataTableReader 内のデータに対応する DataTable を返します。 |
Create |
DataTable の新しいインスタンスを作成します。 |
Dispose() |
MarshalByValueComponent によって使用されているすべてのリソースを解放します。 (継承元 MarshalByValueComponent) |
Dispose(Boolean) |
MarshalByValueComponent によって使用されているアンマネージド リソースを解放し、オプションでマネージド リソースも解放します。 (継承元 MarshalByValueComponent) |
End |
フォームまたは別のコンポーネントで使用する DataTable の初期化を終了します。 初期化は実行時に発生します。 |
End |
データを読み込んだ後、通知、インデックスの維持、および制約をオンにします。 |
Equals(Object) |
指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判断します。 (継承元 Object) |
Get |
前回 DataTable を読み取るか、AcceptChanges() を呼び出した以降にこのデータセットに対して行われたすべての変更が格納されているこのデータセットのコピーを取得します。 |
Get |
前回 DataTable を読み取るか、AcceptChanges() を呼び出した以降にこのデータセットに対して行われたすべての変更が格納されているこのデータセットのコピーを、DataRowState によってフィルター処理した後で取得します。 |
Get |
このメソッドは、Web サービスの XmlSchemaSet を記述する Web サービス記述言語 (WSDL) を含む DataTable インスタンスを返します。 |
Get |
エラーが含まれる DataRow オブジェクトの配列を取得します。 |
Get |
既定のハッシュ関数として機能します。 (継承元 Object) |
Get |
古い.
シリアル化情報オブジェクトを、DataTable のシリアル化に必要なデータで事前設定します。 |
Get |
行の種類を取得します。 |
Get |
このメンバーの詳細については、「GetSchema()」をご覧ください。 |
Get |
IServiceProvider を実装しているオブジェクトを取得します。 (継承元 MarshalByValueComponent) |
Get |
現在のインスタンスの Type を取得します。 (継承元 Object) |
Import |
|
Load(IData |
指定された DataTable を使用し、IDataReader にデータ ソースからの値を設定します。 DataTable が既に行を含んでいる場合、データ ソースからの受信データは既存の行にマージされます。 |
Load(IData |
指定された DataTable を使用し、IDataReader にデータ ソースからの値を設定します。
|
Load(IData |
エラー処理デリゲートを使用し、指定された DataTable を使用して、IDataReader にデータ ソースからの値を設定します。 |
Load |
特定の行を検索し、更新します。 一致する行が見つからない場合は、指定した値を使用して新しい行が作成されます。 |
Load |
特定の行を検索し、更新します。 一致する行が見つからない場合は、指定した値を使用して新しい行が作成されます。 |
Memberwise |
現在の Object の簡易コピーを作成します。 (継承元 Object) |
Merge(Data |
|
Merge(Data |
指定した DataTable を現在の |
Merge(Data |
指定した DataTable を現在の |
New |
テーブルと同じスキーマで新しい DataRow を作成します。 |
New |
DataRow の配列を返します。 |
New |
既存の行から新しい行を作成します。 |
On |
ColumnChanged イベントを発生させます。 |
On |
ColumnChanging イベントを発生させます。 |
On |
PropertyChanged イベントを発生させます。 |
On |
DataTable が削除されることを DataColumn に通知します。 |
On |
RowChanged イベントを発生させます。 |
On |
RowChanging イベントを発生させます。 |
On |
RowDeleted イベントを発生させます。 |
On |
RowDeleting イベントを発生させます。 |
On |
TableCleared イベントを発生させます。 |
On |
TableClearing イベントを発生させます。 |
On |
TableNewRow イベントを発生させます。 |
Read |
|
Read |
指定したファイルから、XML スキーマとデータを DataTable に読み込みます。 |
Read |
指定した DataTable を使用して、XML スキーマとデータを TextReader に読み込みます。 |
Read |
|
Read |
指定したストリームを使用して、XML スキーマを DataTable に読み込みます。 |
Read |
指定したファイルから DataTable に XML スキーマを読み込みます。 |
Read |
指定した DataTable を使用して、XML スキーマを TextReader に読み込みます。 |
Read |
|
Read |
XML ストリームから読み取ります。 |
Reject |
このテーブルを読み込むか、前回 AcceptChanges() を呼び出した以降にこのテーブルに対して行われたすべての変更をロールバックします。 |
Reset() |
DataTable を元の状態にリセットします。 テーブルのすべてのデータ、インデックス、リレーションシップ、および列の削除をリセットします。 DataSet に DataTable が含まれている場合は、テーブルをリセットした後も、テーブルは DataSet の一部です。 |
Select() |
すべての DataRow オブジェクトの配列を取得します。 |
Select(String) |
フィルター基準と一致するすべての DataRow オブジェクトの配列を取得します。 |
Select(String, String) |
フィルター基準と一致するすべての DataRow オブジェクトの配列を、指定した並べ替え順で取得します。 |
Select(String, String, Data |
フィルター基準と一致するすべての DataRow オブジェクトの配列を、指定した状態と一致する並べ替え順に取得します。 |
To |
TableName と DisplayExpression が連結された文字列として存在する場合は、これらを取得します。 |
To |
現在のオブジェクトを表す文字列を返します。 (継承元 Object) |
Write |
|
Write |
DataTable の現在の内容を指定された Stream を使用して XML として書き込みます。 テーブルのデータとその子孫をすべて保存するには、 |
Write |
指定した DataTable を使用して、XmlWriteMode の現在のデータを、指定したファイルに書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
指定した DataTable を使用して、XmlWriteMode の現在のデータを、指定したファイルに書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
指定したファイルを使用して DataTable の現在の内容を XML で書き込みます。 |
Write |
指定したファイルを使用して DataTable の現在の内容を XML で書き込みます。 テーブルのデータとその子孫をすべて保存するには、 |
Write |
指定したファイルと DataTable を使用して、XmlWriteMode の現在のデータを書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
指定したファイルと DataTable を使用して、XmlWriteMode の現在のデータを書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
DataTable の現在の内容を指定された TextWriter を使用して XML として書き込みます。 |
Write |
DataTable の現在の内容を指定された TextWriter を使用して XML として書き込みます。 テーブルのデータとその子孫をすべて保存するには、 |
Write |
指定した DataTable と TextWriter を使用して、XmlWriteMode の現在のデータを書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
指定した DataTable と TextWriter を使用して、XmlWriteMode の現在のデータを書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
|
Write |
|
Write |
指定した DataTable と XmlWriter を使用して、XmlWriteMode の現在のデータを書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
指定した DataTable と XmlWriter を使用して、XmlWriteMode の現在のデータを書き込みます。オプションでスキーマを書き込むこともできます。 スキーマを書き込むには、 |
Write |
DataTable の現在のデータ構造体を指定されたストリームに XML スキーマとして書き込みます。 |
Write |
DataTable の現在のデータ構造体を指定されたストリームに XML スキーマとして書き込みます。 テーブルのスキーマとその子孫をすべて保存するには、 |
Write |
DataTable の現在のデータ構造体を指定されたファイルに XML スキーマとして書き込みます。 |
Write |
DataTable の現在のデータ構造体を指定されたファイルに XML スキーマとして書き込みます。 テーブルのスキーマとその子孫をすべて保存するには、 |
Write |
指定した DataTable を使用して、TextWriter の現在のデータ構造体を XML スキーマとして書き込みます。 |
Write |
指定した DataTable を使用して、TextWriter の現在のデータ構造体を XML スキーマとして書き込みます。 テーブルのスキーマとその子孫をすべて保存するには、 |
Write |
指定した DataTable を使用して、XmlWriter の現在のデータ構造体を XML スキーマとして書き込みます。 |
Write |
指定した DataTable を使用して、XmlWriter の現在のデータ構造体を XML スキーマとして書き込みます。 テーブルのスキーマとその子孫をすべて保存するには、 |
Column |
DataColumn 内の指定した DataRow の値が変更された後に発生します。 |
Column |
DataColumn 内の指定した DataRow の値が変更されているときに発生します。 |
Disposed |
コンポーネントの Disposed イベントを待機するイベント ハンドラーを追加します。 (継承元 MarshalByValueComponent) |
Initialized |
DataTable が初期化された後に発生します。 |
Row |
DataRow が正常に変更された後に発生します。 |
Row |
DataRow が変更されているときに発生します。 |
Row |
テーブル内の行が削除された後に発生します。 |
Row |
テーブル内の行が削除される直前に発生します。 |
Table |
DataTable が消去された後に発生します。 |
Table |
DataTable が削除されたときに発生します。 |
Table |
新しい DataRow が挿入されると発生します。 |
IList |
このメンバーの詳細については、「ContainsListCollection」をご覧ください。 |
IList |
このメンバーの詳細については、「GetList()」をご覧ください。 |
ISerializable. |
シリアル化情報オブジェクトを、DataTable のシリアル化に必要なデータで事前設定します。 |
IXml |
このメンバーの詳細については、「GetSchema()」をご覧ください。 |
IXml |
このメンバーの詳細については、「ReadXml(XmlReader)」をご覧ください。 |
IXml |
このメンバーの詳細については、「WriteXml(XmlWriter)」をご覧ください。 |
製品 | バージョン |
---|---|
.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 |
この型は、マルチスレッド読み取り操作に対して安全です。 すべての書き込み操作を同期する必要があります。
.NET に関するフィードバック
.NET はオープンソース プロジェクトです。 フィードバックを提供するにはリンクを選択します。