sql >> Databasteknik >  >> RDS >> Sqlserver

Få en delmängd av poster tillsammans med totalt antal rekord

Här är vad jag har gjort (och det är lika snabbt, oavsett vilka poster jag returnerar):

--Parameters include:
@pageNum int = 1,
@pageSize int = 0,



DECLARE 
    @pageStart int,
    @pageEnd int

SELECT
    @pageStart = @pageSize * @pageNum - (@pageSize - 1),
    @pageEnd = @pageSize * @pageNum;


SET NOCOUNT ON;
WITH tempTable AS (
    SELECT
        ROW_NUMBER() OVER (ORDER BY FirstName ASC) AS RowNumber,
        FirstName
        , LastName
    FROM People
    WHERE Active = 1
)

SELECT
    (SELECT COUNT(*) FROM tempTable) AS TotalRows,
    *
FROM tempTable
WHERE @pageEnd = 0
OR RowNumber BETWEEN @pageStart AND @pageEnd
ORDER BY RowNumber


  1. TIMESTAMP() Exempel – MySQL

  2. MySQL gatuadress suddig sökning

  3. Hur kontrollerar jag om filen är en bild som använder PL/SQL?

  4. Hibernate mysql innodb