通用分页的过程--软件自带数据库讲解

select * from dbo.Employees
select * from Orders
select * from Customers

/****************************
安产品出售(OrderDate)时间先后顺序列出产品明细表,
要求:
(1)是CompanyName,LastName,FirstName,OrderDate,Freight,ShipName列的明细的列表
(2)Orders表有830表,列表要分页显示,
传入2个参数:@page int ,@size int 一个表示页数从第一页开始,一个表示这一页有多少行。
请补充完begin end 之间的语句

****************************/
declare @page int;
declare @size int;
set @page=3; /*第三页开始*/
set @size=30;/*每页显示30行*/
begin
declare @Start int /*起始记录*/
declare @end int   /*结束记当*/
    SET @Start = (((@Page - 1) * @Size) + 1)
    SET @End = (@Start + @Size - 1)
/*建一个临时表用于分页*/
CREATE TABLE #PageRow (
 Row int IDENTITY(1,1) PRIMARY KEY,
 OrderID int
)

insert into #PageRow(OrderID)
select OrderID
from Orders
order by OrderDate

select CompanyName,LastName,FirstName,OrderDate,Freight,ShipName
from Orders
inner join Customers on Customers.CustomerID=Orders.CustomerID
inner join Employees on Employees.EmployeeID=Orders.EmployeeID
inner join #PageRow on #PageRow.OrderID=Orders.OrderID
where #PageRow.row >=@Start and #PageRow.row<=@End
end
/*说明:临时表也可以用表变量,但表变量对于动态sql 比较难处理
此方法也可以用于oracle mysql 等*/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值