`

ASP.NET实现Web数据分页浏览

阅读更多

利用ASP.NET开发Web数据库的查询功能模块时,为了减少网络流量,提高页面的访问速度,一般不会将所有的查询结果完全在一页中显示出来,而是将其按照一定规则分成多页进行显示,每页显示一定数目记录。应用数据记录分页技术,可以提高数据的查询性能及页面的显示速度,减轻数据库服务器的负担。


1 分页显示方法概述
 对Web数据库查询结果进行分页显示主要有两种实现方式,分别是浏览器端分页和服务器端分页。浏览器端分页是先将数据库中所有满足查询条件的记录一次性保存下来,然后通过设置每页要显示的记录数,再确定要显示记录的起点和终点来实现分页显示。服务器端分页是根据用户的请求,每次分别从满足查询条件的记录中将规定数目的记录数作读取并显示出来。
 为此,我们采用服务器端分页的方式。在浏览器端进行分页时,为了减少网络的流量,我们采用SQL Server的存储过程进行分页。


2  主要技术


2.1 ADO.NET类
在Web应用系统中,ASP.NET使用ADO.NET将系统前端的Web浏览器和后台的数据库之间联系起来。ADO.NET是.NET Framework提供的一系列类,提供了对关系数据、XML和应用程序数据的访问。

3  分页显示技术的实现
 在此,我们使用System.data.SqlClient(包含访问SQL Server数据库的类)对MS SQL Server2000进行操作,使用ASP.NET中的C#语言进行描述。以笔者开发的“在线考试系统”中的“查看学生留言信息模块”为例来说明该项技术的开发过程。

3.1连接数据库
 要访问数据,必须首先连接数据库,在此我们利用System.data.SqlClient.SqlConnection类来连接SQL Server中Student的数据库。用到主要属性和方法如下:

 

属性/方法

说明

ConnectionString

获取或设置用于打开SQL Server数据库的字符串

Open

使用ConnectionString所指定的属性设置打开数据库连接

Close

关闭与数据库的连接

 

连接字符串如下:

 

SqlConnection SCN = new SqlConnection("server=;database=BSNetExam;uid=sa;pwd=");

 

3.2 存储过程的建立

 

CREATE PROCEDURE PageCut

    @PageSize int=10 , -- 页面大小

    @PageIndex int=1  --当前页数

AS

    declare  @strSQL varchar(500)

    if @PageIndex=1

        set  @strSQL='select top'+str(@PageSize)+'* from tdbLevMess order by rqsj'

    else 

        set  @strSQL='select top'+str(@PageSize)+'  * from tdbLevMess where rqsj not in

        (select top  '+str((@PageIndex-1)*@PageSize)+'  rqsj from tdbpres)  order by rqsj' 

    exec(@strSQL)

GO

 

 

3.3操作数据库

    查询数据操作可以通过多种方式来实现,常用的对象包括SqlCommand对象(表示一个SQL查询或者一个存储过程)和SqlDataAdpater对象(把一个SqlCommand提交给SQL Server数据库)。在此,我们使用SqlCommand对象来操作数据库。

    SqlCommand类位于System.Data.SqlClient空间中,表示要对SQL Server数据库执行的一个Transact-SQL语句或存储过程。本例中用到的属性和方法如下:

属性/方法
 说明

CommandText
 获取或设置要对数据源执行的 Transact-SQL 语句或存储过程。
 
CommandType
 获取或设置一个值,该值指示如何解释 CommandText 属性。
 
Connection
 获取或设置 SqlCommand 的此实例使用的 SqlConnection。
 
Parameters
 获取 SqlParameterCollection。
 
ExecuteReader
 将 CommandText 发送到 Connection 并生成一个 SqlDataReader。
 

    SqlParameter类位于System.Data.SqlClient空间中,表示 SqlCommand 的参数,也可以是它到 DataSet 列的映射。本例中用到的Value属性(获取或设置该参数的值)。

其实现程序如下:

 

SqlCommand SCM=new SqlCommand();  //定义SqlCommand类

SqlDataReader SDR;  //定义SqlDataReader类

private void GridView_Init(int PageSize,int PageIndex)

{

    SCN.Open(); //打开数据库连接

    SCM.Connection = SCN;

    SCM.CommandText = "pagecut"; //执行存储过程

    SCM.CommandType = CommandType.StoredProcedure;

    SqlParameter[] pares ={ new SqlParameter("@PageSize",SqlDbType.Int),

    new SqlParameter("@PageIndex",SqlDbType.Int)};

    pares[0].Value = PageSize;

    pares[1].Value = PageIndex;

    SCM.Parameters.Clear(); //清空参数

    foreach (SqlParameter parameter in pares)

    {

        SCM.Parameters.Add(parameter);

    }

    SDR = SCM.ExecuteReader(); //执行存储过程

    GridView1.DataSource = SDR;  //定义GridView的数据源

    GridView1.DataBind(); // GridView数据源绑定

    SCN.Close(); //关闭连接

}

 

 

3.4 程序的实现

    在Web窗体上,添加一个GridView控件(用于数据的显示),四个LinkButton(用作超级链接,分别为首页、上一页、下一页、末页),一个Label控件。将GridView控件的AllowPaging(是否在GridView中打开分页功能)属性设置为False。我们利用Session对象保存分页程序中的参数。具体程序如下:

 

 

protected void Page_Load(object sender, EventArgs e)

    {//页面初始化

        if (!IsPostBack)  //如果页面不是第一次加载

        {

            int PageCount,PageIndex,PageSize; //定义页面总数、当前页面号、每页记录数

            SCN.Open();

            SCM.CommandText = "select count(*) from tdbLevMess ";

            SCM.Connection = SCN;

            int ReCount = Convert.ToInt32(SCM.ExecuteScalar().ToString());//数据集记录总数

            SCN.Close();

            Session.Add("PageSize", 20); //为共享变量每页记录数PageSize赋值

            PageSize = Convert.ToInt16(Session["PageSize"]);//每页记录数为20

            PageCount=ReCount % PageSize == 0? ReCount / PageSize: ReCount / PageSize + 1;//计算页面的总页数

            Session.Add("PageCount", PageCount); //为共享变量总页数PageCount赋值

            PageIndex = 1;

            Session.Add("PageIndex", PageIndex); //为共享变量总页数PageIndex赋值

            GridView_Init (PageSize, PageIndex); //调用过程为GridView填充数据

            LinkButton1.Enabled = false, LinkButton2.Enabled = false;

            LinkButton3.Enabled = true,LinkButton4.Enabled = true;

            Label1.Text = "第"+PageIndex.ToString() + "页/共" + PageCount.ToString() + "页";

        }

    }

  protected void LinkButton2_Click(object sender, EventArgs e)

    {//上一页按钮

        int PageIndex = Convert.ToInt16( Session["PageIndex"] )- 1;

        int PageCount = Convert.ToInt16( Session["PageCount"]);

        Session.Add("PageIndex", PageIndex);

        int PageSize = Convert.ToInt16(Session["PageSize"]);

        if (PageIndex <= 1)

        {

            LinkButton1.Enabled = false;

            LinkButton2.Enabled = false;

        }

        LinkButton3.Enabled = true;

        LinkButton4.Enabled = true;

        GridView_Init(PageSize, PageIndex);

        Label1.Text = "第" + PageIndex.ToString() + "页/共" + PageCount.ToString() + "页";

    }

 

我们只给出了LinkButton2的代码(实现向上翻页),其它超级链接代码跟此相类似。

 

4   结束语

    查询分页技术是Web应用系统开发中经常遇到的重要工作,选择一种高效的查询分页技术,不仅能大大提高响应速度,而且能提高整个系统性能,节约服务器宝贵资源。

分享到:
评论

相关推荐

    燃料电池汽车Cruise整车仿真模型(燃料电池电电混动整车仿真模型) 1.基于Cruise与MATLAB Simulink联合仿真完成整个模型搭建,策略为多点恒功率(多点功率跟随)式控制策略,策略模

    燃料电池汽车Cruise整车仿真模型(燃料电池电电混动整车仿真模型)。 1.基于Cruise与MATLAB Simulink联合仿真完成整个模型搭建,策略为多点恒功率(多点功率跟随)式控制策略,策略模型具备燃料电池系统电堆控制,电机驱动,再生制动等功能,实现燃料电池车辆全部工作模式,基于项目开发,策略准确; 2.模型物超所值,Cruise模型与Simulink策略有不懂的随时交流; 注:请确定是否需要再买,这种技术类文件出一概不 ;附赠Cruise与Simulink联合仿真的方法心得体会(大概十几页)。

    并列关系-关系图表-鲜艳红色 -3.pptx

    图表分类ppt

    实际项目中三菱fx5u编写的中型程序,用了st fbd ld 混合编程,程序内容完整,控制十来个轴 ,结构清晰 ,用到了结构体,全局变量 ,适合进阶学习

    实际项目中三菱fx5u编写的中型程序,用了st fbd ld 混合编程,程序内容完整,控制十来个轴 ,结构清晰 ,用到了结构体,全局变量 ,适合进阶学习

    并列关系-关系图表-简约折纸-3.pptx

    图表分类ppt

    甘特图-商业图表-稳重色彩 3.pptx

    图表分类ppt

    西南科技大学仿射密码实验报告

    一、实验目的 1.理解仿射密码的基本原理及加密、解密过程。 2.掌握利用 C 语言实现仿射密码加密与解密的基本方法。 3.通过实例观察仿射密码的加密效果及安全性。 4.通过实现简单的古典密码算法,理解密码学的相关概念,如明文、密文、加密密钥、解密密钥、加密算法、解密算法、流密码与分组密码等。

    彩色扇形层级关系图PPT模板-3.pptx

    彩色扇形层级关系图PPT模板-3

    创意铅笔四项并列PPT模板-1.pptx

    图表分类ppt

    大圆套小圆多项包含PPT图表.pptx

    大圆套小圆多项包含PPT图表

    Matlab 运动脉搏数据 基于小波降噪和VMD分解的滤波研究 不同滤波方法的信噪比对比

    Matlab 运动脉搏数据 基于小波降噪和VMD分解的滤波研究 不同滤波方法的信噪比对比

    极简创意PPT时间轴模板.pptx

    图表分类ppt

    CDN技术在网络内容分发的应用解析:工作原理、关键组件及优势

    内容概要:本文详细介绍了CDN (内容分发网络)的技术背景和具体实施方案,旨在帮助技术人员深入了解这一网络优化工具的工作机制。文章首先解释了CDN是如何通过在不同地理位置设立边缘节点来存储缓存内容的,接着重点描述了三个关键组成部分——边缘节点服务器、中心服务器以及负载均衡器的功能,并讨论了它们协同工作的流程。之后阐述了CDN的主要优势,包括提升网站响应时间和内容分发效率、减小源站服务器的压力和支持大规模并发访问等方面的表现。最后列举了几种典型应用场景,如加速静态网页加载速度、保障视频/音频串流质量,还有支持高效的大文件分发等。 适用人群:互联网开发者、运维人员及其他希望改进自己网站或平台性能的专业人士。 使用场景及目标:针对需要优化网站或移动应用程序加载速度的服务提供商来说,采用CDN可以帮助改善用户体验的同时也能节约带宽资源,进而达到降低运营开支的目的。 其他说明:文中不仅讲解了相关概念和技术细节,还提供了实用案例分析以便于读者更加直观的理解CDN的实际应用价值。此外,在选择是否部署CDN时应当考虑自身业务特点和需求,合理规划投入产出比。

    phpAjaxcookbook英文pdf文字版(phpAjax手册)最新版本

    This PDF, available in English, is designed for advanced PHP Ajax learners. It offers 60 simple yet highly effective recipes for the Ajaxification of Web 2.0 sites. Key topics include: - Learning to develop and deploy iPhone web and native applications. - Optimizing the performance of Ajax applications. - Constructing dynamic websites that achieve faster server responses through the asynchronous call feature of PHP Ajax. - Utilizing Ajax for rapid and efficient data access from the server, ther

    机器学习(预测模型):高等教育数学学习评估数据集

    一个专注于高等教育数学学习评估的宝贵资源,它汇集了9546条详尽的记录,为教育领域的数据分析和机器学习研究提供了丰富的素材。该数据集精心设计,能够支持多种机器学习任务,包括分类、回归和聚类等,有助于深入挖掘学生数学学习过程中的关键信息,为教育决策和教学改进提供有力依据。 数据集涵盖了学生回答数学问题的全方位信息。在学生层面,记录了学生ID和国籍,这有助于从不同地域文化背景分析学生的学习表现差异。问题细节方面,每个问题都有独特的ID标识,难度等级分为基础和高级,其中基础问题占比高达82%,高级问题占18%,这种分布反映了数学学习中不同难度层次的覆盖情况。数学主题丰富多样,线性代数主题占比最大,达60%,基础数学占9%,其他主题占31%,涵盖了数学教育的核心领域。子主题进一步细化,向量空间和线性变换是较为突出的两个子主题,分别占比29%和22%,体现了线性代数在数学学习中的重要地位。 数据的预期更新频率为每年,这保证了数据集能够持续反映数学教育领域的最新动态和学生学习情况的变化,使其始终保持时效性和实用性,为教育研究者和实践者提供持续的支持。

    基于java+springboot+vue+mysql的教学辅助平台设计与实现.docx

    基于java+springboot+vue+mysql的教学辅助平台设计与实现.docx

    西南科技大学密码学RSA实验

    内容概要:本文详细描述了RSA密码算法的实现,涵盖从基本原理的理解到密钥生成、数据加密解密的具体编程实践。在密钥生成环节,采用了随机大素数生成、素性检测(使用Miller-Rabin)、以及计算Euler's totient function和选定适当大小的公开指数e和私人指数d的过程;针对加密过程,引入了基于快速模幂算法的数据编码方式,而解密部分,则借助了中国剩余定理(孙子定理),提高了解密速度。同时对可能存在的误差进行了探讨。最后给出了关于如何改进代码性能的方法,并附带解答了一些相关理论问题。 适合人群:熟悉C语言编程,有兴趣深入研究密码学尤其是公共密钥基础设施的专业人士。 使用场景及目标:本报告适用于高校课程作业或是科研项目中的信息安全方向的研究,帮助学生掌握公钥加密机制背后的数学原理和技术细节,提升实际动手能力和解决实际问题的能力。 其他说明:报告还包括了一些附加的内容,比如如何用RSA构建简单的伪随机数生成器,还有讨论了什么情况下加密会产生固定点的现象。这些都是为了加深理解和巩固所学到的知识点提供的补充材料。

    实用的PPT数据表格模板-4.pptx

    实用的PPT数据表格模板-4

    springboot项目基于BS模式的冷链物流系统.zip

    springboot项目基于BS模式的冷链物流系统,含有完整的源码和报告文档

    基于微信小程序的岳阳市美术馆预约平台设计与实现.docx

    基于微信小程序的岳阳市美术馆预约平台设计与实现.docx

    Delphi 12 控件之BDE-Installer-for-RAD-Studio-10-Seattle.7z

    BDE_Installer_for_RAD_Studio_10_Seattle.7z

Global site tag (gtag.js) - Google Analytics