SqlServer 经常使用分页方法总结

SqlServer 经常使用分页方法总结

以下演示样例总结了,SqlServer数据库 经常使用分页方法,仅供学习參考

A、 使用 RowNumber 和 Between And 组合分页:

/********** 使用 RowNumber 和 Between And 组合分页 **********/
CREATE PROC proc_FuzzySearchAndPaging
@pageIndex int,           --页索引
@pageSize int,            --页大小
@SearchKey Nvarchar(10),  --查询keyword
@TotalCount int OutPut    --总数据条数
AS
  BEGIN
       --查询 当前页 数据
       SELECT * FROM(
           SELECT *,[NO]=ROW_NUMBER() OVER(ORDER BY s.s_id DESC) FROM StuInfo s
                  WHERE s.s_name Like(‘%‘[email protected]+‘%‘)
       ) t
       WHERE t.[NO] BETWEEN @pageSize*(@pageIndex-1)+1 AND @pageIndex*@pageSize
       ORDER BY t.s_id DESC

       --总数据条数
       SELECT @TotalCount = COUNT(*) FROM StuInfo s WHERE s.s_name Like(‘%‘[email protected]+‘%‘)
  END
GO

B、使用 TOP 和 NOT IN 组合分页:

/********** 使用 TOP 和 NOT IN 组合分页 **********/
CREATE PROC proc_FuzzySearchAndPaging2
@PageIndex int,             --当前页索引
@PageSize int,              --每页显示的数据条数
@FuzzyKey Nvarchar(20),     --模糊匹配的keyword
@Count int OUTPUT           --总数据条数(用来推断要分多少页)
AS
  BEGIN
      SELECT TOP(@PageSize) * FROM StuInfo s
			  WHERE s.s_name LIKE(‘%‘[email protected]+‘%‘)
			  AND s.s_id NOT IN(
			      SELECT TOP((@PageIndex-1)*@PageSize) s.s_id FROM StuInfo s
			             WHERE s.s_name LIKE(‘%‘[email protected]+‘%‘)
			             ORDER BY s.s_id DESC
			  )
			  ORDER BY s.s_id DESC

     --总数据条数
     SELECT @Count=COUNT(*) FROM StuInfo s WHERE s.s_name LIKE(‘%‘[email protected]+‘%‘)
  END
GO

C、使用 Linq 的 Skip 和 Take 组合分页:

        /// <summary>
        /// 分页
        /// </summary>
        /// <param name="key">查询keyword</param>
        /// <param name="pageIndex">页索引</param>
        /// <param name="pageSize">页大小</param>
        /// <param name="pageCount">总页数</param>
        /// <returns></returns>
        public IList<EA_Script> FuzzyPaging(String key, int pageIndex, int pageSize, ref int pageCount)
        {
            var query = from e in dc.EA_Script
                        where e.FName.Contains(key)
                        orderby e.Id descending
                        select e;

            //总页数
            pageCount = query.Count() % pageSize == 0 ?
                (query.Count() % pageSize) : query.Count() / pageSize + 1;

            return query.Skip(pageIndex - 1).Take(pageSize).ToList();
        }

如有,更好方法欢迎拿出来分享!

扩充:分页时,能够充分借助 暂时表 和  WITH AS 语句提高查询效率

WITH AS语句演示样例:

DECLARE @SearchKey Nvarchar(10)  --查询keyword
WITH t AS(
      SELECT * FROM StuInfo s
             WHERE s.s_name Like(‘%‘[email protected]+‘%‘)
)

暂时表 语句演示样例:

DECLARE @SearchKey Nvarchar(10)  --查询keyword
SELECT * INTO #temp2 FROM (
       SELECT * FROM StuInfo s WHERE s.s_name Like(‘%‘[email protected]+‘%‘)
) u

MySQL 分页

SELECT u.* FROM users AS u
LIMIT ($pIndex-1)*$pSize,$pIndex*$pSize;
时间: 2024-11-09 00:57:38

SqlServer 经常使用分页方法总结的相关文章

sqlserver两种分页方法比较

-- 3000 page(从1开始) 10 pagesize -- 方法1(效率不高): SELECT TOP 10 * FROM [xxx].[oooo] WHERE id NOT IN (SELECT TOP (10*(3000-1)) id FROM [xxx].[oooo] ORDER BY createtime DESC)ORDER BY createtime DESC; 方法2(效率高): SELECT TOP 10 * FROM (SELECT ROW_NUMBER() OVER

SqlServer 常用分页方法总结

SqlServer 常用分页方法总结 下面示例总结了,SqlServer数据库 常用分页方法,仅供学习参考 A. 使用 RowNumber 和 Between And 组合分页: /********** 使用 RowNumber 和 Between And 组合分页 **********/ CREATE PROC proc_FuzzySearchAndPaging @pageIndex int, --页索引 @pageSize int, --页大小 @SearchKey Nvarchar(10)

SqlServer分页方法

/// <summary> /// 使用虚拟表进行分页查询,不适用明确知道列名的查询 /// </summary> /// <param name="sql">sql 如"select * from name where 1=1"</param> /// <param name="pageIndex">页码 如"1"</param> /// <par

C# 分页方法

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Web; namespace System.Web.Mvc //注意修改为与HtmlHelper相同的命名空间{ /// <summary> /// 静态 分页方法 /// </summary> public static class MyHtmlHelper { //HtmlHelper的扩展

mybatis常用经典分页方法

来自棱镜学院-在线IT教育www.prismcollege.com 分页方法一: 可以查看如下代码,新建一个数据库分页基础类 package com.ssm.utils.pagination.pagebounds; import java.util.List; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spr

MongoDB分页处理方案(适用于一般数据库的分页方法)

MongoDB分页处理方案(适用于一般数据库的分页方法) (2012-11-06 17:59:55) 转载▼ 标签: mongodb 分页 数据库 跳转 分类: MongoDB 转载请注明出处:http://blog.sina.com.cn/s/blog_56545fd30101442b.html MongoDB的分页性能是广大使用者所诟病的大问题之一,在大数据量环境下,如果一次跳转的页数过多,如10W多页,可能用户要等上几十秒(瞎掰的数据),有兴趣的可以去看一下这篇文章Paging & Ran

sqlserver字符串拆分(split)方法汇总

--方法0:动态SQL法 declare @s varchar(100),@sql varchar(1000) set @s='1,2,3,4,5,6,7,8,9,10' set @sql='select col='''+ replace(@s,',',''' union all select ''')+'''' PRINT @sql exec (@sql) --方法1:循环截取法 if exists (select * from dbo.sysobjects where id = object

.net分页方法

//记录分页的总条数 DX.Model.Container.PagerDataContainer Container = new DX.Model.Container.PagerDataContainer(); int ActualPageSize = PageSize; #region 总页数 int total = 0; DataSet dsTotal = new DataSet(); StringBuilder sbTotal = new StringBuilder(); if (User

新版数据库分页方法(Sql server2012)

1. ROW_NUMBER() 的分页方法 dbcc freeproccache dbcc dropcleanbuffers set statistics time on set statistics io on set statistics profile on; with #pager as ( select ID,Title,ROW_NUMBER() OVER(Order By ID) as rowid from Article_Detail ) select ID,Title from