sql >> Database >  >> RDS >> Sqlserver

Een subset van records verkrijgen samen met het totale aantal records

Dit is wat ik heb gedaan (en het is net zo snel, ongeacht welke records ik terugstuur):

--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. lijstweergave toont de gegevens uit de database in Android

  2. Oracle trigger die controlebeperking op maandelijkse basis

  3. ONLY_FULL_GROUP_BY uitschakelen

  4. python 2.7 naar python 3.4 fout niet-ondersteunde operandtype(s) voor %:'bytes' en 'dict'