Efficient Pagination with Skip/Take

Efficient pagination using OFFSET-FETCH on SQL Server.

Execution Time

29 ms

Page Size

50

Current Page

471 / 489

Total Records

24441

Items per page: 25 50 100 200

Page 471 Results Showing 23501 - 23550 of 24441

ID Name Category Price Stock Rating Reviews SKU
24060 Bulk Product e7246a55 Home & Garden $206.76 444 1.9 12 BULK-07060d18
24061 Bulk Product 9f73412c Sports & Outdoors $323.67 336 0.4 43 BULK-b9ac2188
24062 Bulk Product f4b23249 Electronics $573.25 254 3.3 82 BULK-c6702482
24063 Bulk Product 6f879f15 Clothing $952.82 304 1.2 39 BULK-2b8696d3
24064 Bulk Product 7e68f1bb Clothing $566.81 329 1.2 52 BULK-302fbd04
24065 Bulk Product e375bd59 Clothing $153.15 184 3.2 37 BULK-cdab7bd2
24066 Bulk Product 1f4d0a47 Home & Garden $96.17 85 1.5 23 BULK-35d480b4
24067 Bulk Product f67dc436 Electronics $752.97 98 2.6 95 BULK-d61c4dfa
24068 Bulk Product eeafc796 Books $366.40 472 0.7 96 BULK-2464493a
24069 Bulk Product 301c43bc Toys & Games $13.55 105 4.8 74 BULK-b965d4e5
24070 Bulk Product 5dcd43ac Books $308.21 349 1.7 38 BULK-4247f437
24071 Bulk Product f5188ae5 Electronics $670.12 192 1.9 39 BULK-02ef1bea
24072 Bulk Product af1d8911 Electronics $252.06 99 1.6 28 BULK-51eaa7e8
24073 Bulk Product aa22262d Books $657.68 97 3.9 37 BULK-a6d9ba15
24074 Bulk Product 60758540 Home & Garden $812.69 462 1.9 54 BULK-8268893e
24075 Bulk Product 97d0c091 Books $567.25 202 3.2 91 BULK-4c7fc02e
24076 Bulk Product 83fac95e Home & Garden $652.07 416 2.5 52 BULK-b54c16af
24077 Bulk Product bdf56a8f Books $897.55 438 4.1 3 BULK-b45649cc
24078 Bulk Product 2bd9d1f3 Sports & Outdoors $685.58 387 1.0 29 BULK-a2aae873
24079 Bulk Product ec8f4a73 Clothing $1,002.01 40 1.6 47 BULK-6e436951
24080 Bulk Product dd2b59fc Sports & Outdoors $626.90 463 0.1 17 BULK-c59a0412
24081 Bulk Product 164fb7bc Home & Garden $337.85 267 0.4 93 BULK-3277cb1b
24082 Bulk Product c53a867e Books $287.30 168 1.9 68 BULK-1dc73408
24083 Bulk Product 48a16c5e Clothing $878.89 498 3.9 78 BULK-5ab9c4ed
24084 Bulk Product d7456b1f Clothing $440.23 287 1.4 1 BULK-e25bf459
24085 Bulk Product 079620d6 Home & Garden $396.32 21 4.5 21 BULK-af0236cd
24086 Bulk Product 45c3b45b Clothing $321.92 356 0.0 92 BULK-ebbb5e84
24087 Bulk Product ec567524 Clothing $13.07 403 2.9 98 BULK-235449e0
24088 Bulk Product 827e3281 Clothing $159.23 51 4.4 57 BULK-801d2e5e
24089 Bulk Product bcfafef6 Books $912.81 0 4.0 77 BULK-023e2e6e
24090 Bulk Product dd0f3124 Electronics $751.19 496 1.3 76 BULK-9d918f53
24091 Bulk Product 8eefbe82 Books $367.99 344 2.0 79 BULK-37aebd34
24092 Bulk Product 8cec1f50 Electronics $907.26 10 4.8 87 BULK-2ef88571
24093 Bulk Product 27a83703 Toys & Games $23.13 353 2.5 99 BULK-f08402c6
24094 Bulk Product 386febee Toys & Games $542.07 402 4.7 37 BULK-e0b8ebec
24095 Bulk Product a30908e4 Books $410.92 292 0.8 81 BULK-b37fa4af
24096 Bulk Product 9ad90c91 Home & Garden $215.45 306 4.7 31 BULK-42c89913
24097 Bulk Product 58327ee4 Toys & Games $904.55 461 5.0 82 BULK-5804fa4e
24098 Bulk Product d8ed4b10 Books $489.53 3 2.2 54 BULK-8cd1e1f7
24099 Bulk Product f563c04e Clothing $486.00 42 2.8 15 BULK-5ca01031
24100 Bulk Product 00d60974 Home & Garden $134.05 310 2.4 39 BULK-5f2c6d2a
24101 Bulk Product e1d625f8 Books $673.36 6 2.8 34 BULK-d05813e6
24102 Bulk Product 6611761e Toys & Games $933.96 111 3.0 59 BULK-2893fa73
24103 Bulk Product 338f02b4 Electronics $842.15 417 2.5 26 BULK-daf13dfc
24104 Bulk Product 33415369 Books $752.69 429 3.1 32 BULK-f5072341
24105 Bulk Product 026408f1 Toys & Games $732.47 12 1.0 48 BULK-344d7d26
24106 Bulk Product fed07be5 Clothing $540.14 284 2.0 26 BULK-7a287581
24107 Bulk Product 81a17f97 Toys & Games $952.74 115 0.3 81 BULK-f2de5281
24108 Bulk Product d6b38574 Toys & Games $527.41 370 1.1 69 BULK-d61ca477
24109 Bulk Product bde8c1dd Home & Garden $937.33 56 0.2 51 BULK-c7347527
Implementation Code
// Efficient pagination with Skip and Take
public async Task<PaginatedResult<DemoProduct>> GetPaginatedProductsAsync(int page, int pageSize)
{
    // Get total count (cached if possible)
    var totalCount = await _context.DemoProducts.CountAsync(p => p.IsActive);
    
    // Get page of results
    var items = await _context.DemoProducts
        .Where(p => p.IsActive)
        .OrderBy(p => p.Id) // Important: Must have ORDER BY for consistent paging
        .Skip((page - 1) * pageSize) // OFFSET in SQL
        .Take(pageSize) // FETCH NEXT in SQL
        .AsNoTracking() // No tracking needed for read-only
        .ToListAsync();

    return new PaginatedResult<DemoProduct>
    {
        Items = items,
        TotalCount = totalCount,
        Page = page,
        PageSize = pageSize
    };
}
Pagination Best Practices
  • Always use OrderBy: Skip/Take require stable sorting for consistent results
  • Use AsNoTracking(): Pagination queries are typically read-only
  • Consider caching: Cache total count if dataset changes infrequently
  • Limit max page size: Prevent users from requesting too many records at once
  • Use indexed columns: Ensure ORDER BY columns are indexed for performance