最新下载
热门教程
- 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;
相关文章
- 钉钉网页版快捷入口-钉钉网页版一键登录官网 03-13
- 英语cet4成绩查询入口-cet4级成绩查询官网入口 03-13
- 老王磁力官网2026最新版-老王磁力最新网址发布页 03-13
- 哔咔漫画PicACG极速下载器-带可视化界面+多线程极速下载 03-13
- 虫虫漫画在线看入口在哪-2026最新地址与高清免费漫画在线阅读指南 03-13
- 学信网官方学籍验证通道-学信网权威学历认证通道 03-13