SQL分页存储过程和C#中linq分页查询方法

SQL分页存储过程

第一种方法:

[sql]  view plain  copy
  1. if exists(select * from sysobjects where name='usp_BookPage')  
  2. drop procedure usp_BookPage  
  3. go  
  4. create procedure usp_BookPage  
  5. @PageSize int,--每页显示多少  
  6. @CurrentPage int--当前第多少页  
  7. as  
  8. --查询当前分页的数据  
  9. select Top (@PageSize)BookId, BookName, BarCode, Author, PublisherId, PublishDate, BookCategory, UnitPrice, BookImage, BookCount, Remainder, BookPosition, RegTime  
  10. from Books   
  11. where BookId not in (select Top (@PageSize *(@CurrentPage -1)) BookId   
  12. from Books order by RegTime asc )  
  13. order by RegTime asc  
  14. go  


第二种方法


[sql]  view plain  copy
  1. if exists(select * from sysobjects where name='usp_BookPage')  
  2. drop procedure usp_BookPage  
  3. go  
  4. create procedure usp_BookPage  
  5. @PageSize int ,--每页显示多少页  
  6. @CurrentPage int --当前第多少页  
  7. as  
  8. --查询分页  
  9. select top (@PageSize) * from  
  10. (select ROW_NUMBER() over (order by bookid) as rownumber,*  
  11. from Books)A where rownumber >(@CurrentPage -1)*@PageSize   
  12. go  


c#中linq分页查询

[csharp]  view plain  copy
  1. #region 数据分页  
  2. int page = 0;  
  3. if (Request.Form["page"]!=null && Request .Form["page"].Length >0)  
  4. {  
  5.     page = Convert.ToInt32(Request.Form["page"]);  
  6. }  
  7. int pagesize = 10;  
  8. if (Request .Form["pageSize"]!=null && Request .Form["pageSize"].Length >0)  
  9. {  
  10.     pagesize = Convert.ToInt32(Request.Form["pageSize"]);  
  11. }  
  12. #endregion  
  13. list_New = list_New.OrderBy(u => u.UserId).Skip((page - 1) * pagesize).Take(pagesize).ToList();  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值