WPF Datagrid-自动刷新

6

我有一个数据网格,显示绑定到SQL Server数据库的表格。我想设置一个计时器,每60秒检查是否有更新,然后显示最新的更新数据。

到目前为止,我已经为数据网格创建了一个事件处理程序,其中包括对象调度计时器。

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

这是我的查询语句,用于填充数据表格。

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);
     }
}
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();
}

很好的入门级说明。谢谢。让我试一下,然后回来告诉你。 - Indhi
1
通过实现 INotifyPropertyChanged 接口来实现这个功能是一个不错的主意吗? - Indhi
1
这将是一个很好的机会去了解ObservableCollection<T>INotifyPropertyChanged。如果您创建了一个自定义类并将网格绑定到ObservableCollection<MyCustomClass>,则在更新时不需要重新绑定。我强烈建议您这样做,以增加WPF方面的学习收益。 :) - Khan
@JefferyKhan:你好Jeffery,如何使用INotifyPropertyChanged实现datagrid项的自动刷新?我尝试使用MVVM方式从sqlserver显示datagrid,并且成功了,但是当我的数据源发生更改时,它没有反映在我的UI中。您能否发布另一种使用INotifyPropertyChanged和ObservableCollection的解决方案? - demo_user

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接