最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
关于msdn上面的《Web 窗体页创建分页的数据访问》的改进
时间:2022-06-30 10:16:12 编辑:袖梨 来源:一聚教程网
前段时间做了第一个ASP.NET项目,很简单的。在DataGrid分页的时候遇到小问题,就参考msdn的例子做了一个。实际过程中发现似乎有点问题,改进了一下:
链接:ms-help://MS.MSDNQTR.2003FEB.2052/vbcon/html/vbwlkwalkthroughdisplayingdatainlistboxesonwebformspage.htm
说明:该文章使用了两个sql语句,目的是向前翻页的时候和向后翻页的时候分别使用不同的语句。改进以后只用一条语句就可以。我在项目里面使用的是存储过程:
CREATE PROCEDURE selectAllUser
(
@Id int
)
AS
select top 15 Id,UserName,IDcard,Sex,Birthday,MailAddr,GetscholarTime
from UserInfo
where Id>=@Id
GO
关键代码如下:
///
/// 从数据库读取从userID开始的15条记录并显示
///
///
private void showAllUser(int userID)
{
ManageDB managedb = new ManageDB();
int count = managedb.getUserCount(); //这个方法获取总记录数
if(count == -1)
{
Response.Redirect("error.aspx",true);
return;
}
count = count/this.gridUser.PageSize;
SqlDataReader reader = managedb.getAllUser(userID);
this.gridUser.DataSource = reader;
this.gridUser.DataBind();
reader.Close();
ViewState["CurrentPage"] = CurrentPage;
ViewState[CurrentPage.ToString()] = this.gridUser.Items[0].Cells[0].Text;
if(CurrentPage <=0)
{
this.btnPrevious.Enabled = false;
}
if(CurrentPage >= count)
{
this.btnNext.Enabled = false;
}
}
下一页按钮点击事件:
private void btnNext_Click(object sender, System.EventArgs e)
{
this.btnPrevious.Enabled = true;
CurrentPage = (int)(ViewState["CurrentPage"]);
CurrentPage ++;
//下面的代码有个+1操作,这个是必须的,这样保证了取得的记录没有重复的。
int lastID = Convert.ToInt32(this.gridUser.Items[this.gridUser.PageSize-1].Cells[0].Text) + 1;
链接:ms-help://MS.MSDNQTR.2003FEB.2052/vbcon/html/vbwlkwalkthroughdisplayingdatainlistboxesonwebformspage.htm
说明:该文章使用了两个sql语句,目的是向前翻页的时候和向后翻页的时候分别使用不同的语句。改进以后只用一条语句就可以。我在项目里面使用的是存储过程:
CREATE PROCEDURE selectAllUser
(
@Id int
)
AS
select top 15 Id,UserName,IDcard,Sex,Birthday,MailAddr,GetscholarTime
from UserInfo
where Id>=@Id
GO
关键代码如下:
///
/// 从数据库读取从userID开始的15条记录并显示
///
///
private void showAllUser(int userID)
{
ManageDB managedb = new ManageDB();
int count = managedb.getUserCount(); //这个方法获取总记录数
if(count == -1)
{
Response.Redirect("error.aspx",true);
return;
}
count = count/this.gridUser.PageSize;
SqlDataReader reader = managedb.getAllUser(userID);
this.gridUser.DataSource = reader;
this.gridUser.DataBind();
reader.Close();
ViewState["CurrentPage"] = CurrentPage;
ViewState[CurrentPage.ToString()] = this.gridUser.Items[0].Cells[0].Text;
if(CurrentPage <=0)
{
this.btnPrevious.Enabled = false;
}
if(CurrentPage >= count)
{
this.btnNext.Enabled = false;
}
}
下一页按钮点击事件:
private void btnNext_Click(object sender, System.EventArgs e)
{
this.btnPrevious.Enabled = true;
CurrentPage = (int)(ViewState["CurrentPage"]);
CurrentPage ++;
//下面的代码有个+1操作,这个是必须的,这样保证了取得的记录没有重复的。
int lastID = Convert.ToInt32(this.gridUser.Items[this.gridUser.PageSize-1].Cells[0].Text) + 1;
相关文章
- 王者荣耀侦探能力大测试攻略 王者荣耀侦探能力大测试怎么过 11-22
- 无期迷途主线前瞻兑换码是什么 11-22
- 原神欧洛伦怎么培养 11-22
- 炉石传说网易云音乐联动怎么玩 11-22
- 永劫无间手游确幸转盘怎么样 11-22
- 无期迷途主线前瞻兑换码是什么 无期迷途主线前瞻直播兑换码介绍 11-22