私は3秒ごとにリフレッシュするDataGridを持っています。リフレッシュ中にDatatableは毎回予期せずリセットされます。私がしているのは、あるデータテーブルの値を別のデータテーブルに追加することです。Datatableが予期せずリセットされる
ただし、 'DefaultView.ToTable'を使用すると、データが保存されます。
基本的には、dtTopSQLとdtCurTopSQLという2つのデータセットがあります。
dtTopSQL新しいデータを取得し、データテーブルdtCurTopSQLに追加すると、dtCurTopSQLに行を保存する必要があります。
// Initial Load the Datatable Structure
private void Main_Load(object sender, EventArgs e)
{
dtTopSQL.Columns.Add("SQL_ID", typeof(string));
dtTopSQL.Columns.Add("Count", typeof(Int16));
dtTopSQL.Columns.Add("CurTime", typeof(DateTime));
}
// Timer start refreshing the datagrid
private void timer_TimerTopSQL(object sender, EventArgs e)
{
dtTopSQL.Clear(); // Clear before the Fill
odaTopSQL = new OracleDataAdapter(getTopSQLString, oradb);
odaTopSQL.Fill(dtTopSQL);
getTopSQL();
}
// Merging datatable starts here.
public void getTopSQL()
{
for (int i = 0; i < dtTopSQL.Rows.Count; i++)
{
bool isDupe = false;
for (j = 0; j < dtCurTopSQL.Rows.Count; j++)
{
if (dtTopSQL.Rows[i][0].ToString() == dtCurTopSQL.Rows[j][0].ToString())
{
dtCurTopSQL.Rows[j][1] = int.Parse(dtCurTopSQL.Rows[j][1].ToString()) + int.Parse(dtTopSQL.Rows[i][1].ToString());
dtCurTopSQL.Rows[j][2] = CurDate;
isDupe = true;
break;
}
}
if (!isDupe)
{
dtCurTopSQL.ImportRow(dtTopSQL.Rows[i]);
dtCurTopSQL.Rows[j][2] = CurDate;
}
}
ugTopSQL.DataSource = dtCurTopSQL; // Bind the merged Datatable.
}
上記のコードは、データをバインドする前に以下のコードを使用すると機能します。
しかし、なぜ私は理解できませんか? DefaultView.ToTableを使用せずにデータを保存したい
お願いします。
回答ありがとうございます。しかし、それは動作しませんでした。 –