2012-07-12 63 views
0

我看了很多其他類似的問題,不能得到這個爲我的聲明工作。這是當前工作的SELECT語句,我需要添加分頁。Sql SELECT語句與分頁vb.net

 "SELECT TOP 15 * FROM tblEvents WHERE (dbo.fnEventSearchDistance(@CityLat, " & _ 
     "@CityLong, latitude, longitude) <= @Radius AND (StartDate >= GETDATE())) " 

這是我一直能得到最接近的一次。

 "SELECT ROW_NUMBER() OVER(ORDER BY StartDate) AS RowNum, * FROM tblEvents " & _ 
     "WHERE RowNum BETWEEN ((@PageNum - 1) * @PageSize + 1) " & _ 
     "AND (@PageNum * @PageSize) " & _ 
     "ORDER BY StartDate" 

     comm2.Parameters.AddWithValue("@PageSize", 25) 
     comm2.Parameters.AddWithValue("@PageNum", 2) 

我需要重寫第一個SELECT語句納入分頁,在那裏我可以添加pageSize的SELECT語句和頁次參數

+1

你的問題是什麼? – 2012-07-12 15:20:09

+0

重寫第一個SELECT語句以添加分頁 – 2012-07-12 15:20:45

+1

有什麼不起作用?除了'AS RowNum' – Bort 2012-07-12 15:22:32

回答

2

假設SQL Server 2008和以前,你應該試試這個:

"SELECT col1, col2 FROM (SELECT ROW_NUMBER() OVER(ORDER BY StartDate) AS RowNum, * FROM tblEvents) AS E " & _ 
"WHERE RowNum BETWEEN ((@PageNum - 1) * @PageSize + 1) " & _ 
"AND (@PageNum * @PageSize) " & _ 
"ORDER BY StartDate" 

請注意,我把col1, col2上的選擇,你應該把你需要的列放在那裏。 對於SQL Server 2012,這是很簡單的:

"SELECT * FROM tblEvents ORDER BY StartDate " & _ 
"OFFSET (@PageNum - 1) * @PageSize ROWS FETCH NEXT @PageNum ROWS ONLY" 
+0

偉大的分頁查詢..但我也需要知道查詢的總記錄數..如何可以做到這一點而不詢問兩次? – 2017-04-13 10:46:31

0

試試這個:

;With ranked AS 
(
    SELECT ROW_NUMBER() OVER(ORDER BY StartDate) AS RowNum, * 
    FROM tblEvents 
) 
SELECT * FROM Ranked 
WHERE RowNum BETWEEN ((@PageNum - 1) * @PageSize + 1) 
    AND (@PageNum * @PageSize) 
    ORDER BY StartDate 
1
CREATE PROCEDURE [dbo].[usp_PageResults_NAI] 
(
    @startRowIndex int, 
    @maximumRows int 
) 
AS 

DECLARE @first_id int, @startRow int 

-- A check can be added to make sure @startRowIndex isn't > count(1) 
-- from employees before doing any actual work unless it is guaranteed 
-- the caller won't do that 

-- Get the first employeeID for our page of records 
SET ROWCOUNT @startRowIndex 
SELECT @first_id = employeeID FROM employees ORDER BY employeeid 

-- Now, set the row count to MaximumRows and get 
-- all records >= @first_id 
SET ROWCOUNT @maximumRows 

SELECT e.*, d.name as DepartmentName 
FROM employees e 
    INNER JOIN Departments D ON 
     e.DepartmentID = d.DepartmentID 
WHERE employeeid >= @first_id 
ORDER BY e.EmployeeID 

SET ROWCOUNT 0 

GO 
0

不能引用ROW_NUMBERWHERE子句中,使用​​可以與呼叫幫助。

WITH Paging AS 
(
    SELECT ROW_NUMBER() OVER (ORDER BY StartDate) AS RowNum 
    , * 
    FROM tblEvents 
) 
SELECT * 
FROM Paging AS p 
WHERE p.RowNum BETWEEN ((@PageNum - 1) * @PageSize + 1) 
    AND (@PageNum * @PageSize) 
ORDER BY p.StartDate ASC; 

在SQL 2012開始,你將有機會獲得OFFSET FETCHORDER BY幫助使分頁更簡單,更高效。