用SQL_Server_2005_实现结果集分页

用SQL_Server_2005_实现结果集分页

ID:38420708

大小:17.51 KB

页数:3页

时间:2019-06-12

用SQL_Server_2005_实现结果集分页_第1页
用SQL_Server_2005_实现结果集分页_第2页
用SQL_Server_2005_实现结果集分页_第3页
资源描述:

《用SQL_Server_2005_实现结果集分页》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、用SQLServer2005实现结果集分页介绍有了SQLServer2005之后,我们使用分页查询比老版本容易多了。在本文中,我将主要用到的是NorthWind数据库,所以你也可以仿照编写我所列举的范例。我尽量使例子简单化;因为任何复杂的东西都会都会造成混淆。我将从“传统”的方法着手,比如:SELECT,TOP,然后慢慢进入具体的SQLServer2005分页的例子。背景我常常会被问到这样的一个问题或者说一系列这样的问题,“你如何在SQL中进行分页?在有很多个记录的情况下,你又如何做,比如10000个记录或者更

2、多呢?我思索着答案。更确切地说,我考虑了更多的问题并且我都认真去思考,“这必定是一个普篇的问题,每一个开发人员必须处理或者说解决的。具有非常大的数据库集的工作和分页大小是怎样的?从多种表所得到的结果集又是如何?”因此,我决定具体结合SQLServer2005来研究这些问题。下面的方法是至今为止最容易的,建议采纳。但是这是非常罕见的,并非易事。 select*frommytableWhereIDbetween20and30 SQLTopSQLTop(从结果集返回记录)非常善于从结果集的每个尾部返回大量的记录。下面

3、的例子通过命令qty获得了前10名顾客。在论坛上这是一个非常普骗的问题。尽管TOP也可以拉动一定百分比的记录,但是我们这里不讨论。 Selecttop10*fromcustomers--Thisisaverybasicexample.selectTOP10Customers.CustomerID,Customers.CompanyName,count(*)OrderCountfromCustomersinnerjoinOrdersonOrders.CustomerID=Customers.CustomerIDG

4、ROUPBYCustomers.CustomerID,Customers.CompanyNameORDERBYOrderCountDESC 这是很有用的。当你要把记录从11拉到20时,你就可以使用临时表。 --SELECTFirst30recordsintoTemptableSELECTTOP30*INTO#TEMPfromCustomersORDERBYCompanyNameASC --SelectBottom10recordsinanothertemptable SELECTTOP10*INTO#TEMP2

5、from#TempORDERBYCompanyNameDESC --GETTHERECORDS SELECT*FROM#TEMP2 这对少数前几个页面或者前几个用户是种惩罚。如果拥有这样的用户,他们想从一页一页之后返回页面,你将以使1000条记录返回10条来结束,这是非常低效的。你可以在第一个临时表中内置一个身份,然后用一个SELECT声明来作替代。TOP的替代有一个这样的TOP替代,它使用的是rowcount(行计数)。使用行计数要小心。如果它不关闭的话,将你将陷入各种各样的困境。SETrowcount10S

6、ELECT*fromCustomersORDERBYCompanyNameWITH,ROW_NUMBER(行数)andOVER这对SQLServer2005来说非常新鲜并且看上去非常有用。下面一个例子显示从一个结果集得到20至19条记录。刚开始,我有一点惊奇,但是我浏览了查询器后我发现它是如此简单。WithCustAS   (SELECTCustomerID,CompanyName,   ROW_NUMBER()OVER(orderbyCompanyName)asRowNumber   FROMCustomer

7、s)select*fromCustWhereRowNumberBetween20and30SQLServer2005的WITH指定了一个临时命名的结果,很像SQLServer以前版本中的临时表。但是,输入部分是ROW_NUMBER和OVER声明,它根据公司的名称在每组中创建行数。这就像通过命令条文向临时表添加一个身份种子。我希望你赞成我的看法。如果不,运行代码并查看结果集。对大表来说速度真的非常快;表的速度超过250,000条记录,对此我留下了深刻的印象。一起整合到储存过程中现在我们把它一起整合到储存过程,这个

8、储存过程我们可以通过应用程序来使用。我不打算展示.NETDatagrid或者相似的控件,因为是本文探讨范围之外。下面看到的储存过程使用了灵活的页面大小和页面数目,所以你可以随意地选择任何页面。这样,如果你想跳过前十页去寻找某一条记录就非常方便了。下面的例子是从第一页开始分页的,而不是从第0页,但也可以随意更改。 CREATEPROCGetCustomersByPage @PageSiz

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。