sql server2005 分页特性

在sql server 2005的新功能中,比较西黄分页功能,通过查询函数row_number over(order by field)实现是提取分页数据当页的记录,此功能原理上和临时表差不多,不过通过插叙语句操作就快捷多了,做了个demo,分页效果很好。
1、新建一个default.aspx页面,内容很简单,就一个数据控件和一个分页导航标记条。
<body>
    <form id="form1" runat="server">
    <div>
  <asp:DataGrid ID="datalist" runat="server"></asp:DataGrid>
  <asp:Label ID="pager" runat="server"></asp:Label>
    </div>
    </form>

</body>

2、在代码里,主要根据传送的参数去数据表里去当前页的记录,每次都只去一页的记录。

protected void Page_Load(object sender, EventArgs e)
        {
            Bind();
        }
        
//获取记录总数
        private int RowCount
        {
            
get
            {
                
string connStr = ConfigurationManager.ConnectionStrings["connstr"].ToString();
                SqlConnection conn 
= new SqlConnection(connStr);
                conn.Open();
                
string sqlStr = "select count(1) from tbl_MailList";
                SqlDataAdapter ada 
= new SqlDataAdapter(sqlStr, conn);
                DataSet ds 
= new DataSet();
                ada.Fill(ds);
                conn.Close();
                
return int.Parse(ds.Tables[0].Rows[0][0].ToString());
            }
        }
        
//绑定数据
        private void Bind()
        {  
            
//首页地址
            string url="default.aspx";
           
            
//每页数量
            int size = 10;
            
//总记录
            int TotalCount = RowCount;
            
//开始记录
            int start=1;
            
try
            {
                start
=int.Parse(Request.Params["start"].ToString());
            }
            
catch
            {

            }
            
//结束记录
            int end=size;
            
try
            {
                end
=int.Parse(Request.Params["end"].ToString());
            }
            
catch
            {
            }

            
string connStr = ConfigurationManager.ConnectionStrings["connstr"].ToString();
            SqlConnection conn 
= new SqlConnection(connStr);
            conn.Open();
            
string sqlStr = "select * from (select *,row_number() over(order by AddrId) as row from tbl_maillist) as mail where row between "+start+" and "+end;
            SqlDataAdapter ada 
= new SqlDataAdapter(sqlStr, conn);
            DataSet ds 
= new DataSet();
            ada.Fill(ds);
            conn.Close();
            datalist.DataSource 
= ds.Tables[0];
            datalist.DataBind();
            
//当前页码
            int CurrentPage=1;
            
try
            {
                CurrentPage
=int.Parse(Request.Params["CurrentPage"].ToString());
            }
            
catch
            {
            }
            
//分页数量
            int PageCount = TotalCount / size;
            
if (TotalCount % size != 0)
            {
                PageCount
=PageCount+1;
            }
            
//呈现页面导航
            StringBuilder sb = new StringBuilder();
            
//只有1页
            if (PageCount < 2||CurrentPage == 1)
            {
                sb.Append(
"首页");
                sb.Append(
"&nbsp;&nbsp;上一页");
            }
            
else
            {
                sb.Append(
"<a href="+url+"?start=1&end="+size+"&CurrentPage=1>首页</a>");
                sb.Append(
"&nbsp;&nbsp;<a href="+url+"?start="+((CurrentPage-2)*size+1+"&end="+ (CurrentPage-1)*size+"&CurrntPage="+(CurrentPage-1)+">上一页</a>");
            }
            
//超过10页只显示10页
            if (PageCount > 10)
            {  
                
for (int intLoop = 1; intLoop < 11; intLoop++)
                {
                    
//当前页没有超连接
                    if (CurrentPage == intLoop)
                    {
                        sb.Append(
"&nbsp;" + intLoop.ToString());
                    }
                    
else
                    {
                        sb.Append(
"&nbsp;<a href=" + url + "?start=" + ((intLoop - 1* size + 1+ "&end=" + (intLoop * size) + "&CurrentPage=" + intLoop + ">" + intLoop + "</a>");
                    }
                }
                sb.Append(
"");
            }
            
else
            {
                
for (int intLoop = 1; intLoop < PageCount + 1; intLoop++)
                {
                    
//当前页没有超连接
                    if (CurrentPage == intLoop)
                    {
                        sb.Append(
"&nbsp;" + intLoop.ToString());
                    }
                    
else
                    {
                        sb.Append(
"&nbsp;<a href=" + url + "?start=" + ((intLoop - 1* size + 1+ "&end=" + (intLoop * size) + "&CurrentPage=" + intLoop + ">" + intLoop + "</a>");
                    }
                }
            }
           
            
if (PageCount < 2||CurrentPage==PageCount)
            {
               
                sb.Append(
"&nbsp;&nbsp;下一页");
                sb.Append(
"&nbsp;&nbsp;末页");
            }
            
else
            {
                sb.Append(
"&nbsp;&nbsp;<a href="+url+"?start="+((CurrentPage*size)+1)+"&end="+(CurrentPage+1)*size+"&CurrentPage="+(CurrentPage+1)+">下一页</a>");
                sb.Append(
"&nbsp;&nbsp;<a href="+url+"?start="+(((PageCount-1)*size)+1)+"&end="+PageCount*size+"&CurrentPage="+PageCount+">末页</a>");
            }

            pager.Text 
= sb.ToString();
          
        }

  执行效果很快,适合大量数据的分页。

转载于:https://www.cnblogs.com/dfsxh/archive/2008/09/09/1287234.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/305202.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c#爬虫-1688官网自动以图搜图

背景在1688有个功能&#xff0c;就是上传图片&#xff0c;就可以找到类似的商品。如下网址 &#xff1a;https://www.1688.com/这时候&#xff0c;我们可以使用程序来代替&#xff0c;大批量的完成图片上传功能。实现思路1、找到图片上传接口post请求&#xff0c;form表单中有s…

php代码里加图片,php如何添加图片

php如何添加图片&#xff1f;php中插入图片的代码是什么&#xff1f;PHP插入图片&#xff0c;实际还是输出HTML代码比如&#xff1a;echo ;还可以直接用PHP生成图片显示出来php的gd库可以生成多种图像文件&#xff0c;如gif,png,jpg,wbmp,xpm等&#xff0c;下面来看一个生成正方…

matlab优化算法案例分析与应用_最优化计算与matlab实现(18)——粒子群优化算法——权重改进的粒子群算法...

参考资料《精通MATLAB最优化计算&#xff08;第二版&#xff09;》编程工具Matlab 2019a目录石中居士&#xff1a;最优化计算与Matlab实现——目录​zhuanlan.zhihu.com权重改进的粒子群算法在微粒群算法的可调整参数中&#xff0c;惯性权重 是最重要的参数&#xff0c;较大的 …

两个list怎么对比数据_基于日志的回放对比系统设计

‍‍‍‍‍‍点击关注“有赞coder”获取更多技术干货哦&#xff5e;作者&#xff1a;马力部门&#xff1a;新零售测试一、背景上半年公司的网关系统进行了重构&#xff0c;需要把零售业务已有的网关接口迁移到新网关上。这些接口每天都有成千上万次请求&#xff0c;为商家提供各…

让人眼花缭乱的视错觉,太酷炫了!

盯~ 原理&#xff1a;这只死盯着人看的小短手并不是一个普通的纸模&#xff0c;它的眼睛鼻子和嘴也都不在正常的位置上&#xff0c;它的脸其实是凹下去的。 错觉的关键在于我们的大脑对凹面和凸面的加工方式&#xff0c;以及大脑对从图形中挑出一张脸的执着和能力。大脑想要…

swot分析模板_什么是SWOT分析图?怎样绘制SWOT分析思维导图,这样操作很简单

什么是SWOT分析图&#xff1f;大到企业小到个人都会使用到SWOT来对自身所具备的能力进行分析&#xff0c;这也印证了SWOT分析图的重要性&#xff0c;下面我们一起来深度了解SWOT分析吧&#xff01;&#xff01;一&#xff1a;什么是SWOT分析图所谓SWOT分析图是基于内外部竞争环…

有哪些命令行的软件堪称神器?

ag 比grep、ack更快的递归搜索文件内容。 tig 字符模式下交互查看git项目&#xff0c;可以替代git命令。 mycli mysql客户端&#xff0c;支持语法高亮和命令补全&#xff0c;效果类似ipython&#xff0c;可以替代mysql命令。 jq json文件处理以及格式化显示&#xff0c;支持高…

代码 | 一天一点代码坏味道(1)

【代码精进】| 总结/Edison Zhou作为一个后端工程师&#xff0c;想必在职业生涯中都写过一些不好维护的代码。本文是我学习《代码之丑》的学习总结&#xff0c;今天第一天发车&#xff0c;先来看看在命名上的一些常犯的坏味道。0为何要品代码坏味道Martin Flower在《重构》一书…

python base64编码_JS和Python实现AES算法

1. AES原理AES算法是典型的对称加密算法&#xff0c;AES原理可以学习这两篇文档&#xff1a;漫画&#xff1a;什么是AES算法&#xff1a;https://www.toutiao.com/i6783550080784794124/AES加密算法的详细介绍与实现&#xff1a;https://blog.csdn.net/qq_28205153/article/det…

当你老了,一生最后悔什么?大数据告诉你!

‍ 当你老了&#xff0c;一生最后悔什么&#xff1f;

@scheduled注解配置时间_SpringBoot2.0实战(32)配置定时任务

定时任务的几种实现方式&#xff1a;Timer&#xff1a;Java自带的java.util.Timer类&#xff0c;这个类允许你调度一个java.util.TimerTask任务。使用这种方式可以让你的程序按照某一个频度执行&#xff0c;但不能在指定时间运行。一般用的较少。Quartz&#xff1a;使用Quartz&…

小心 Enum Parse 中的坑

小心 Enum Parse 中的坑Intro最近使用枚举的时候&#xff0c;踩了一个小坑&#xff0c;分享一下&#xff0c;主要是枚举从 int 值转成枚举时可能会遇到Sample来看下面的示例&#xff1a;首先定义一个枚举&#xff1a;public enum Color : byte {Red 0,Green 1,Blue 2, }来看…

python判断列表是否为空_Jinja2: 判断返回的列表是否为空

我们在使用 Python 或者 Ansible 来进行自动化任务的时候常常会进行一些数据的组合和提取来生成文件。但是我们需要为不同的情况来做分析和进行判断。如果我们需要对返回的 list 来进行提取的时候我们常常只是运行一个 for loop 就解决了问题。如果输出如下所示&#xff1a;{&q…

在php中使用kind,KindEditor 4.x在PHP中的应用实例!

1.解压放入php项目静态资源文件夹&#xff0c;如下图&#xff1a;Paste_Image.png2.如果只是php使用&#xff0c;可以删除其它类型语言的文件夹&#xff0c;文件结构如下图&#xff1a;Paste_Image.png3.打开php文件夹&#xff0c;更改upload_json.php里文件上传目录文件夹至Up…

你的朋友国庆假期都去了哪里玩?微信大数据告诉你!最远的朋友圈签到竟然来自……

国庆中秋八天假 你是出门四处浪浪浪了 还是躺在家里看朋友圈里的世界名景 10月8日&#xff0c;微信发布《国庆假期微信大数据报告》 从出境人数、热门地区、境外消费等角度 全方位展示国庆期间微信用户的出游情况 哪些城市的人最爱出境游&#xff1f; 哪个国家是最热门的出境目…

mysql安装版和解压版哪个好_红米k30pro变焦版和荣耀30pro哪个好-哪个更值得入手...

红米k30pro变焦版和荣耀30pro&#xff0c;两款手机都有着很强的性能配置&#xff0c;也在同等的价位上&#xff0c;今天我们就来对比一下&#xff0c;看看红米k30pro变焦版和荣耀30pro哪个性价比更高&#xff0c;有哪些配置区别&#xff01;一、主要参数对比荣耀30 Pro红米K30 …

记一次CPU持续100%及分析方法

背景 某天晚上八点多&#xff0c;突然收到一个 CPU 爆表的告警。过了一会&#xff0c;几个业务线就开始反馈系统变慢了。后面紧急处理了这台机器后&#xff0c;让业务先恢复正常。后续看了一下监控&#xff0c;拔凉拔凉的。这个服务是比较重要的一个老业务&#xff0c;.NET Fra…

php中请写出定义变量的两种方法,php定义变量几种

1、定义常量define("CONSTANT", "Hello world.")&#xff1b;常量只能包含标量数据(boolean&#xff0c;integer&#xff0c;float 和 string)&#xff0c;调用常量时&#xff0c;只需要简单的用名称取得常量的值&#xff0c;而不能加“$”符号。注: 常量和…

c语言三目运算符_C语言中的三目运算符是啥?有何用处?

一般来说&#xff0c;C语言中的三目运算符为a?b:c即有三个参与运算的量。由条件运算符组成条件表达式的一般形式为&#xff1a;表达式1? 表达式2&#xff1a;表达式3求值规则为&#xff1a;如果表达式1的值为真&#xff0c;则以表达式2 的值作为条件表达式的值&#xff0c;否…