DataGrid分页数据库存储过程而实现的分页 和sp_cursor 分页

本文介绍了一个ASP.NET应用程序中实现数据分页的方法,并详细解释了如何通过按钮和页面索引更改事件来控制数据网格的当前显示页面,同时展示了如何更新页面状态信息。

AI 时代程序员必备技能

Codex、Claude Code、Cursor、Hermes Agent、OpenClaw等工程化实战专栏 ,讲透 AI 如何接管脏活累活

 

private void Page_Load(object sender, System.EventArgs e)
{
   OpenDatabase();
   BindGrid();
   
this.count.Text = "您搜索出 "+ds.Tables[0].Rows.Count.ToString()+" 条记录";
}

 
private void OpenDatabase() 
  

   cn 
= new SqlConnection(C.ConfigurationSettings.AppSettings[0]);
   cn.Open();
  }
 

public void BindGrid() 
        

            ds 
= new DataSet();
            SqlDataAdapter da 
= new SqlDataAdapter(sql,cn);
            da.Fill(ds,
"Document");
            
this.Datagrid2.DataSource = ds.Tables["Document"].DefaultView;
            
this.Datagrid2.DataBind();
            ShowStats(); 
        }
 
private void ShowStats() 
        

            lblCurrentIndex.Text 
= "第 " + (DataGrid2.CurrentPageIndex + 1).ToString() + " 页"
            
            lblPageCount.Text 
= "总共 " + DataGrid2.PageCount.ToString() + " 页"
        }
 

//上页下页最前最后按钮事件
private void Button_Click(object sender, System.Web.UI.ImageClickEventArgs e)
        
{
            
string  arg = ((ImageButton)sender).CommandArgument.ToString();
            
switch(arg)
            
{
                
case ("first"):
                    DataGrid2.CurrentPageIndex 
= 0;
                    
                    
break;
                
case ("prev"):
                    
if(DataGrid2.CurrentPageIndex>0)
                    
{
                        DataGrid2.CurrentPageIndex
--;
                        
                    }
    
                    
break;
                
case ("next"):
                    
if(DataGrid2.CurrentPageIndex<(DataGrid2.PageCount-1))
                    
{
                        DataGrid2.CurrentPageIndex
++;
                        
                    }

                    
break;
                
case ("last"):
                    DataGrid2.CurrentPageIndex 
= DataGrid2.PageCount-1;
                    
                    
break;
                
default:
                    DataGrid2.CurrentPageIndex 
= Convert.ToInt32(arg);
                    
                    
break;
            }

            BindGrid();
            
this.ShowStats();
        
        }


private void OnPageIndexChanged(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
        
{
            
int startIndex ;
            startIndex 
= DataGrid2.CurrentPageIndex * DataGrid2.PageSize;
            DataGrid2.CurrentPageIndex 
= e.NewPageIndex;
            BindGrid();
            ShowStats();
        }

//按钮go的代码
private void go_Click(object sender, System.Web.UI.ImageClickEventArgs e)
            
{
                
if(to.Text.Trim()!="")
                
{   
                    
int index=Int32.Parse(to.Text.Trim())-1;
                    
if(index>=0&&index<DataGrid2.PageCount)
                    
{
                        DataGrid2.CurrentPageIndex
=index;
                    }

                }

                BindGrid();
            }


//在窗体设计器生成的代码中加入
                                                                
this.First.Click += new System.Web.UI.ImageClickEventHandler(this.Button_Click);
            
this.Prev.Click += new System.Web.UI.ImageClickEventHandler(this.Button_Click);
            
this.Next.Click += new System.Web.UI.ImageClickEventHandler(this.Button_Click);
            
this.Last.Click += new System.Web.UI.ImageClickEventHandler(this.Button_Click);
                                                                
this.go.Click += new System.Web.UI.ImageClickEventHandler(this.go_Click);
                                                                
this.DataGrid2.PageIndexChanged += new System.Web.UI.WebControls.DataGridPageChangedEventHandler(this.OnPageIndexChanged);



AI 时代程序员必备技能

Codex、Claude Code、Cursor、Hermes Agent、OpenClaw等工程化实战专栏 ,讲透 AI 如何接管脏活累活

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值