扩展性很好的一个分页存储过程分析
发布时间:2021-12-25 00:53:14 所属栏目:MsSql教程 来源:互联网
导读:这是经常用的一个分页存储过程 希望大家指点不足 复制代码 代码如下: USE [a6756475746] GO /****** Object: StoredProcedure [dbo].[tbl_order_SearchWhereAndPage] Script Date: 11/01/2011 09:37:39 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER O
|
这是经常用的一个分页存储过程 希望大家指点不足 复制代码 代码如下: USE [a6756475746] GO /****** Object: StoredProcedure [dbo].[tbl_order_SearchWhereAndPage] Script Date: 11/01/2011 09:37:39 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER PROCEDURE [dbo].[tbl_order_SearchWhereAndPage] @AllCount int OUTPUT, @PageIndex int, @PageSize int , @minDate datetime, @maxDate datetime AS begin DECLARE @PageLower int set @PageLower=@PageSize * @PageIndex DECLARE @PageUpper int set @PageUpper= @PageLower + @PageSize - 1 DECLARE @SearchSQL nvarchar(4000) set @SearchSQL='SELECT * ,( ROW_NUMBER() OVER (ORDER BY [ID] DESC) -1 ) AS RowNumber FROM tbl_order WHERE (1=1) ' DECLARE @SearchSQLCount nvarchar(4000) set @SearchSQLCount='SELECT @count=Count(*) FROM tbl_order WHERE (1=1) ' declare @Result [varchar](5000) set @Result='' if @minDate>convert(datetime,'1900-1-2') begin set @Result=@Result+' and oDeliveryDate >= '''+convert(varchar(20),@minDate)+'''' end if @maxDate > convert(datetime,'1900-1-2') begin set @Result=@Result+' and oDeliveryDate <= '''+convert(varchar(20),dateadd(dd,1,@maxDate))+'''' end set @SearchSQLCount=@SearchSQLCount+@Result set @SearchSQL=@SearchSQL+@Result SET @SearchSQL = 'WITH t AS (' + @SearchSQL +' ) SELECT * FROM t WHERE [RowNumber] BETWEEN '+ convert(varchar(50),@PageLower) +' AND '+ convert(varchar(50),@PageUpper) + ' ORDER BY RowNumber ' exec (@SearchSQL) exec sp_executesql @SearchSQLCount ,N'@count as int out' ,@AllCount out print @SearchSQL print @AllCount end exec (@Result) (编辑:百科站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 如何选择和排序不在Groupy中的列按SQL语句 – Oracle
- sql – Oracle 10g中的Pivot / Crosstab查询(动态列号)
- sql-server – 您可以在数据透视表中小计行和/或列吗?
- sql – 选择仅包含特定表的数据库
- 数据库设计 – 是否有DBMS允许引用视图的外键(而不仅仅是基
- 如何从ColdFusion中的查询对象获取SQL?
- sql – 我的更新语句与Oracle中的连接有什么问题?
- 编写Postgres获取或创建SQL查询
- sql-server – 为什么在SQL Server 2012中设置空结果的查询
- sql-server – 我是否在unicode的“insert into”语句中使用
站长推荐
热点阅读

