-
SQL行号排序和分页(SQL查询中插入行号自定义分页的另类实现)
(一)行号显示和排序1.SQLServer的行号A.SQL2000使用identity(int,1,1)和临时表,可以显示行号SELECTidentity(int,1,1)ASROWNUM,[DataID]INTO#1FROMDATASorderbyDataID;SELECT*FROM#1B.SQL2005提供一个很好用的函数row_number(),可以直接用来显示行号,当然也可以使用SQL2000的identitySELECTrow_number()over(ORDERBYDataID)ASROWNUM,[DataID]FROMDATAS;这里如果添加排序功能,则先排序再添加行号2.ORACLE的行号显示使用ROWNUMSELECTROWNUM,[DataID]FROMDATASorderbyDataID注意:先加行号再排序,如果想排序好再加行号就要使用子查询3.取前n条数据A.SQL版selecttopn[DataID]fromDATASB.ORACLE版SELECT[DataID]FROMDATASwhereROWNUM<=n其中,n>=1ORACLE的ROWNUM...
数据库操作教程 2022-09-23 17:10:11 -
mssql高效的分页存储过程分享
最近在做一个几百万条数据的分页查询,研究了各种方案,在本机上用项目的实际数据库做测试,测试过程isvery痛苦,不堪回首ing。现在废话不多说,直接上结果,相信这也是大多数搜索答案的人最愿意看的方式...
数据库操作教程 2022-09-23 17:04:31 -
分页查询效率最高
复制代码代码如下:/*日期:2009-03-19功能:根据各种条件获取游戏国家任务列表数据*/Createprocedure[dbo].[PrGs_Nation_Task_GetList]@PageSizeint=100,--每页显示记录条数,默认为100@PageIndexint=1,--当前提取要显示的页码,默认为1,数据库根据PageSize,PageIndex计算返回一页数据@RetTotalintoutput,--记录总数@RetCountintoutput,--返回记录数@RetPageIndexintoutput,--输出当前页码@ReturnDescvarchar(128)output--返回操作结果描述asbeginsetnocountonsetxact_abortonset@RetTotal=0set@RetCount=0set@RetPageIndex=@PageIndex--多条件取值declare@Errint--错误declare@PageCountint--总页数declare@BeginRIDint--开始行Riddeclare@MaxRowint--最...
数据库操作教程 2022-09-23 17:01:04 -
oracle,mysql,SqlServer三种数据库的分页查询的实例
MySql:MySQL数据库实现分页比较简单,提供了LIMIT函数。一般只需要直接写到sql语句后面就行了...
数据库操作教程 2022-09-23 17:00:55 -
AspNetPager分页控件存储过程
复制代码代码如下:SETQUOTED_IDENTIFIERONGOSETANSI_NULLSONGOALTERPROCEDUREusp_PagingLarge@TableNamesVARCHAR(200),--表名,可以是多个表,但不能用别名@PrimaryKeyVARCHAR(100),--主键,可以为空,但@Order为空时该值不能为空@FieldsVARCHAR(200),--要取出的字段,可以是多个表的字段,可以为空,为空表示select*@PageSizeINT,--每页记录数@CurrentPageINT,--当前页,0表示第1页@FilterVARCHAR(200)='',--条件,可以为空,不用填where@GroupVARCHAR(200)='',--分组依据,可以为空,不用填groupby@OrderVARCHAR(200)=''--排序,可以为空,为空默认按主键升序排列,不用填orderbyASBEGINDECLARE@SortColumnVARCHAR(200)DECLARE@OperatorCHAR(2)DECLARE@SortTableVARCHAR(200...
数据库操作教程 2022-09-23 17:00:37 -
sqlserver通用分页存储过程
复制代码代码如下:createproccommonPagination@columnsvarchar(500),--要显示的列名,用逗号隔开@tableNamevarchar(100),--要查询的表名@orderColumnNamevarchar(100),--排序的列名@ordervarchar(50),--排序的方式...
数据库操作教程 2022-09-23 16:57:59 -
目前用到的两个分页存储过程代码
第一个,取得数据总行数复制代码代码如下:setANSI_NULLSONsetQUOTED_IDENTIFIERONgoALTERPROCEDURE[sq8reyoung].[fenye_num](@TableNamesNVARCHAR(200),@Filternvarchar(200))ASIF@Filter=''SET@Filter='WHERE1=1'ELSESET@Filter='WHERE'+@FilterEXECUTE('selectcount(*)from'+@TableNames+''+@Filter)第二个取得分页数据复制代码代码如下:setANSI_NULLSONsetQUOTED_IDENTIFIERONgoALTERPROCEDURE[sq8reyoung]...
数据库操作教程 2022-09-23 16:56:01 -
GridView自定义分页的四种存储过程
1.为什么不使用GridView的默认分页功能首先要说说为什么不用GridView的默认的分页功能,GridView控件并非真正知道如何获得一个新页面,它只是请求绑定的数据源控件返回适合规定页面的行,分页最终是由数据源控件完成。当我们使用SqlDataSource或使用以上的代码处理分页时...
数据库操作教程 2022-09-23 16:53:49 -
sql2005存储过程分页示例代码
复制代码代码如下:--分页存储过程示例AlterPROCEDURE[dbo].[JH_PageDemo]@pageSizeint=9000000000,@pageIndexint=1,@orderByNvarchar(200)=''--不加orderByASSETNOCOUNTON--声明变量DECLARE@selectVARCHAR(3048);DECLARE@fromVARCHAR(512);DECLARE@RowNumberVARCHAR(256);DECLARE@conditionnVARCHAR(3990);DECLARE@groupByvarchar(50);DECLARE@sqlVARCHAR(3998);DECLARE@RowStartIndexINT;DECLARE@RowEndIndexINT;BEGINSETNOCOUNTonIF@orderBy<>''Set@orderBy='ORDERBY'+@orderBy;elseSet@orderBy='ORDERBYUserid';SET@select='selectuserid,username,';--...
数据库操作教程 2022-09-23 16:52:11 -
sqlserver分页的两种写法分别介绍
第一种是最传统的写法,用存储过程中的变量作为分页的乘数复制代码代码如下:[c-sharp]viewplaincopyprint?createprocp_paged1@pageSizeint,@currentPageintasselecttop(@pageSize)*fromstudentwhereidnotin(selecttop(@pageSize*(@currentPage-1))idfromstudent)goexecp_paged12,3createprocp_paged1@pageSizeint,@currentPageintasselecttop(@pageSize)*fromstudentwhereidnotin(selecttop(@pageSize*(@currentPage-1))idfromstudent)goexecp_paged12,3--SQLServer2005以后的分页语句复制代码代码如下:[c-sharp]viewplaincopyprint?createprocp_paged2@pageStartint,@pageEndintasselect*fro...
数据库操作教程 2022-09-23 16:49:08 -
SqlServer2012分页方法分析(offsetandfetch)
其中offsetandfetch最重要的新特性是用来分页,既然要分析分页,就肯定要和之前的分页方式来比较了,特别是Row_Number()了,在比较过程中,发现了蛮多,不过最重要的,通过比较本质,得出了优劣,也和大家一起分享下。准备工作,建立测试表:Article_Detail,主要是用来存放一些文章信息,测试的时间,都是从网易上面转载的新闻,同时,测试表数据字段类型是比较均匀的,为了更好的测试,表结构如下图: 内容:数据量:129,991条记录语法分析1.NTILE()的分页方法NTILE()方法可以用来分页,但是应用场景十分的狭窄,并且性能差劲,和Row_Number()与offsetfetch分页比起来没有任何优势,也只有在只读表上面分页的话,还是比较合适的;虽然不好用,但是还能来分页的,所以只简单的介绍下...
数据库操作教程 2022-09-23 16:48:35 -
存储过程实现(可带查询条件/万能分页/通用)
假设数据库中有张表,表名是UserName,字段分别是ID(int),Name(nvarchar),Age(int)。如果不带查询条件存储过程是:复制代码代码如下:CREATEPROCEDURE[dbo].[UserName]@pageIndexint,@pageSizeintASdeclare@minint;declare@maxint;set@min=@pageSize*(@pageIndex-1)+1;set@max=@pageSize*@pageIndex;withmyTableas(selectID,Name,Age,Row_Number()over(orderbyID)asrownumfrom[UserName])selectID,Name,AgefrommyTablewhererownumbetween@minand@maxRETURN这个分页存储过程很不实用,并且表是固定的...
数据库操作教程 2022-09-23 16:47:56