6

SQL サーバー DB にバインドされたテーブルを表示するデータグリッドがあります。60 秒ごとにタイマーを設定して、更新をチェックし、最新の更新データを表示したいと思います。

これまでのところ、オブジェクト ディスパッチャー タイマーを含む datagrid 用の event_handler を作成しました。

private void dataGrid1_loaded(object sender, RoutedEventArgs e)
{
    DispatcherTimer dispatcherTimer = new DispatcherTimer();
    dispatcherTimer.Tick += new EventHandler(dispatcherTimer_Tick);
    dispatcherTimer.Interval = new TimeSpan(0, 0, 60);
    dispatcherTimer.Start();
}

データベースから新しく更新されたデータを処理するために、イベント ハンドラーをさらに処理する方法がわかりません。

dispatcherTimer_Tick

これは、データグリッドを埋めるために使用される私の select ステートメントです。

private void Page_Loaded(object sender, RoutedEventArgs e)
{
    try
    {
        String selectstatement = "select top 2 ItemID, ItemName,ConsumerName, Street, DOJ from ConsumarTB order by ItemID ";
        da = new SqlDataAdapter(selectstatement, con);
        ds = new DataSet();
        da.Fill(ds);
        dataGrid1.ItemsSource = ds.Tables[0].DefaultView;

     }
     catch (SqlException e)
     {
        Console.WriteLine(e.Message);
     }
}
4

1 に答える 1

8

上記のものを改善する方法はたくさんあります。しかし、これが私が最初に試すことです。

以下は、ページの読み込み時にデータグリッドにデータを入力し、タイマーを 60 秒ごとに設定します。タイマーが作動すると、グリッドにデータを再度ロードするメソッドが呼び出されます。

//On PageLoad, populate the grid, and set a timer to repeat ever 60 seconds
private void Page_Loaded(object sender, RoutedEventArgs e)
{
    try
    {
        RebindData();
        SetTimer();
    }
    catch (SqlException e)
    {
        Console.WriteLine(e.Message);
    }
}

//Refreshes grid data on timer tick
protected void dispatcherTimer_Tick(object sender, EventArgs e)
{
    RebindData();
}

//Get data and bind to the grid
private void RebindData()
{
    String selectstatement = "select top 2 ItemID, ItemName,ConsumerName, Street, DOJ from ConsumarTB order by ItemID ";
    da = new SqlDataAdapter(selectstatement, con);
    ds = new DataSet();
    da.Fill(ds);
    dataGrid1.ItemsSource = ds.Tables[0].DefaultView;
}

//Set and start the timer
private void SetTimer()
{
    DispatcherTimer dispatcherTimer = new DispatcherTimer();
    dispatcherTimer.Tick += new EventHandler(dispatcherTimer_Tick);
    dispatcherTimer.Interval = new TimeSpan(0, 0, 60);
    dispatcherTimer.Start();
}
于 2012-12-21T14:50:48.173 に答える