快捷搜索:

分页存储过程(二)在MS SQL Server中返回更加准确

在我的应用SQL Server2005的新函数构造分页存储历程中,我提到了应用ROW_NUMBER()函数来代替top实现分页存储历程。

然则光阴长了,又发清楚明了新问题,便是主子表的分页查询。例如:订单表和订单明细表,要求是查询订单,第二页,每页10条

代码

--应用row_unmber()实现分页

--原先我们想要的结果是10条订单,结果却不是10条订单,而是10条明细

--着实是针对的子表进行分页了,订单并不是要显示的个数,出来的个数是明细的个数

--便是由于主表和子表联合查询的结果,主表记录和子表记录是1:N的关系,一个主表记录有多个明细

select * from

(SELECT ROW_NUMBER () OVER (ORDER BY oi.createdate DESC) AS rownumber,oi.orderseqno ,od.OrderDetailID

FROM OrderInfo oi LEFT JOIN OrderDetail od ON oi.OrderSeqNO=od.OrderSeqNO

WHERE oi.OrderSeqNO LIKE '%2%'

) AS o

WHERE rownumber BETWEEN 10 AND 20

您可能还会对下面的文章感兴趣: