【问题标题】:Manual pagination:- next button手动分页:- 下一步按钮
【发布时间】:2013-10-04 03:15:31
【问题描述】:

在按钮单击事件上,我执行了一个新查询,我得到了一个新表,但我无法将它填充到同一个网格视图中。有什么原因我可以在哪里使用模式而不是数据表。

private void GetData()//This method Displays the Datatable onto the Grid
{            
    int intCount = 0;
    int.TryParse(txt_messagecount.Text, out intCount);
    DataTable dtData = null;
    //dtData = _objIMRSData.GetData(txt_fromdate.Text, txt_todata.Text, txt_messagecount.Text);
    dtData = _objIMRSData.GetTransactionData( txt_fromdate.Text, txt_todata.Text,intCount );           
    grd_transactionLog.DataSource = dtData;
    grd_transactionLog.DataBind();
    dtData.Clear();        
}

//On Button click event I execute a new query i get a new table 
//but i am unable to   populate it on to the same grid view
protected void btn_next_Click(object sender, EventArgs  e)
{ 
    int messageCount = int.Parse(txt_messagecount.Text);
    string lastRecord = grd_transactionLog.Rows[messageCount-1].Cells[1].Text;
    DataTable dtData1 = null;
    //dtData = _objIMRSData.GetData(lastRecord, txt_todata.Text, txt_messagecount.Text);
    dtData1 = _objIMRSData.GetTransactionData(lastRecord, txt_todata.Text, messageCount);
    //grd_transactionLog.Columns.Clear();            
    grd_transactionLog.DataSource = dtData1;
    grd_transactionLog.DataBind();
    dtData1.Clear();
}

【问题讨论】:

  • 页面加载时是否调用GetData()
  • 旁注:DataTable.Clear 是一种相对昂贵的方法,您无缘无故地使用它。
  • DataTable.Clear()不仅不需要,dtData1也不需要设置为null。

标签: c# asp.net gridview datatable schema


【解决方案1】:

重新分配datasource。在click 事件中执行此操作。

grd_transactionLog.DataSource = null;
grd_transactionLog.DataSource = dtData1;

【讨论】:

  • 感谢您的回答,但解决方案适合我写的问题,我发送了错误的查询,所以它弹出了相同的数据表
猜你喜欢
  • 1970-01-01
  • 2018-11-09
  • 1970-01-01
  • 1970-01-01
  • 2023-04-03
  • 2023-01-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多