42

私は C# の学習プロセスに取り組んでおり、これまでのところ順調に進んでいます。しかし、私は今、最初の「何を言う?」を打ちました。一瞬。

DataTable は、典型的なコレクションの動作だけでなく、DataTable.Select を介して、Rows コレクションへのランダムな行アクセスを提供します。ただし、この機能を DataRow.Delete に関連付けることはできないようです。これまでのところ、テーブルから 1 つまたは複数の行を条件付きで削除するには、これが必要なようです。

int max = someDataTable.Rows.Count - 1;
for(int i = max; i >= 0; --i)
{
    if((int)someDataTable.Rows[i].ItemArray[0] == someValue)
    {
        someDataTable.Rows[i].BeginEdit();
        someDataTable.Rows[i].Delete();
    }
    else
        break;
}
someDataTable.AcceptChanges();

しかし、私はこのコードに満足していません。どちらも私は確信していません。私は何かが欠けているに違いない。条件付きで 1 つ以上の行を削除する必要がある場合、Rows コレクションを順番にヒットする必要がありますか?

(for の反転は気にしないでください。データテーブルの最後から削除しています。それで問題ありません)

4

4 に答える 4

77

データセットにクエリを実行し、選択した行をループして削除として設定できます。

var rows = dt.Select("col1 > 5");
foreach (var row in rows)
    row.Delete();

...そして、簡単にするためにいくつかの拡張メソッドを作成することもできます...

myTable.Delete("col1 > 5");

public static DataTable Delete(this DataTable table, string filter)
{
    table.Select(filter).Delete();
    return table;
}
public static void Delete(this IEnumerable<DataRow> rows)
{
    foreach (var row in rows)
        row.Delete();
}
于 2009-10-20T00:19:19.767 に答える
45

LINQ を使用し、選択文字列の実行時評価を回避するワンライナーを次に示します。

someDataTable.Rows.Cast<DataRow>().Where(
    r => r.ItemArray[0] == someValue).ToList().ForEach(r => r.Delete());
于 2012-05-07T19:38:10.380 に答える
10

これを試すのに便利なWindowsボックスはありませんが、DataViewを使用して次のようなことができると思います:

DataView view = new DataView(ds.Tables["MyTable"]);
view.RowFilter = "MyValue = 42"; // MyValue here is a column name

// Delete these rows.
foreach (DataRowView row in view)
{
  row.Delete();
}

ただし、これはテストしていません。あなたはそれを試してみてください。

于 2009-10-20T00:23:18.723 に答える