Efficient Pagination with Skip/Take

Efficient pagination using OFFSET-FETCH on SQL Server.

Execution Time

23 ms

Page Size

50

Current Page

226 / 489

Total Records

24441

Items per page: 25 50 100 200

Page 226 Results Showing 11251 - 11300 of 24441

ID Name Category Price Stock Rating Reviews SKU
11810 Bulk Product 38eb1bde Home & Garden $871.02 327 0.7 81 BULK-96650738
11811 Bulk Product 71f8dfa4 Clothing $854.19 235 2.9 41 BULK-cb6ac060
11812 Bulk Product cfb3b4c3 Toys & Games $983.21 55 0.6 76 BULK-a8387de5
11813 Bulk Product 07985605 Sports & Outdoors $580.62 131 3.7 71 BULK-f8905969
11814 Bulk Product 103a8e51 Toys & Games $1,006.42 497 3.1 8 BULK-a48880dd
11815 Bulk Product cd758c33 Toys & Games $369.23 416 4.8 60 BULK-fbf48976
11816 Bulk Product af804d8b Toys & Games $354.73 460 0.0 40 BULK-b34512d9
11817 Bulk Product 622aab2b Books $460.52 265 2.0 37 BULK-70fcf395
11818 Bulk Product d4353c44 Home & Garden $450.51 266 4.4 86 BULK-531ae73c
11819 Bulk Product 311c0976 Toys & Games $487.01 288 4.9 13 BULK-4e52efce
11820 Bulk Product 0e9ff3fa Books $486.11 158 1.3 82 BULK-c57d075e
11821 Bulk Product 295e03e6 Toys & Games $150.05 454 0.1 25 BULK-5be87f77
11822 Bulk Product 16a4d230 Toys & Games $841.71 287 3.4 31 BULK-86c22294
11823 Bulk Product 26342d59 Home & Garden $630.11 158 0.5 29 BULK-736a0be1
11824 Bulk Product 741d85df Toys & Games $310.61 419 1.1 35 BULK-b0526723
11825 Bulk Product 6a26491b Home & Garden $606.20 316 2.7 60 BULK-2fc0de4b
11826 Bulk Product 116d31e5 Books $737.30 73 2.3 34 BULK-946114a1
11827 Bulk Product ec866f1c Electronics $857.46 293 3.5 97 BULK-fbbd8e3d
11828 Bulk Product 2e02bceb Electronics $266.41 494 0.3 19 BULK-aea2ffa8
11829 Bulk Product eafa26a7 Sports & Outdoors $358.00 6 4.4 7 BULK-89d89fe5
11830 Bulk Product 5de7a6e8 Sports & Outdoors $476.55 229 1.6 46 BULK-2f30ae99
11831 Bulk Product 09807e9f Toys & Games $607.57 409 2.4 88 BULK-6a9ecc89
11832 Bulk Product ffad1879 Home & Garden $539.66 476 3.9 15 BULK-9491a2ba
11833 Bulk Product 7915fe94 Sports & Outdoors $693.37 70 2.5 28 BULK-8155c8f5
11834 Bulk Product efc8ad3e Sports & Outdoors $506.23 29 4.0 6 BULK-722fc0b0
11835 Bulk Product 2e62e74e Electronics $58.89 20 2.8 42 BULK-e64b6b55
11836 Bulk Product 2dd6962e Sports & Outdoors $815.88 367 3.8 43 BULK-d40ad4d8
11837 Bulk Product a0de75e9 Clothing $405.88 68 1.7 64 BULK-448b567a
11838 Bulk Product 3bbfbc1c Toys & Games $773.53 469 3.2 82 BULK-f6271868
11839 Bulk Product 206a5516 Clothing $20.01 137 1.8 75 BULK-d1e18ec6
11840 Bulk Product d04a06e1 Books $434.80 391 3.2 46 BULK-72a1888b
11841 Bulk Product f4e22404 Clothing $129.14 347 4.8 71 BULK-5ff6e8f1
11842 Bulk Product 4226fc9d Sports & Outdoors $721.88 58 1.4 28 BULK-7ede690a
11843 Bulk Product 3b8a2fcc Toys & Games $647.57 407 2.2 68 BULK-d5e5b0fa
11844 Bulk Product 24deead5 Toys & Games $882.51 412 2.3 95 BULK-df9b1b82
11845 Bulk Product 5c932ff8 Toys & Games $188.19 71 3.8 55 BULK-dcd9876c
11846 Bulk Product 4be53d09 Sports & Outdoors $970.75 465 4.9 51 BULK-b3a77a84
11847 Bulk Product 54fad82e Sports & Outdoors $607.40 31 3.9 38 BULK-a7f9a428
11848 Bulk Product a3c623df Toys & Games $38.50 51 4.3 72 BULK-73c7d878
11849 Bulk Product 30542e42 Clothing $398.81 431 0.5 32 BULK-6adc32cd
11850 Bulk Product 8f4a086a Clothing $813.91 270 1.5 40 BULK-46bbe587
11851 Bulk Product f0388dfe Electronics $388.92 99 1.9 11 BULK-e660570d
11852 Bulk Product db5bd664 Toys & Games $885.98 234 2.1 71 BULK-5456120a
11853 Bulk Product a0a4e124 Books $267.69 301 2.6 48 BULK-1f44fe01
11854 Bulk Product eefc7162 Electronics $153.74 218 0.9 52 BULK-d3c21e41
11855 Bulk Product 63094874 Toys & Games $288.35 304 3.2 74 BULK-11c8a3bb
11856 Bulk Product 3098223b Toys & Games $387.32 347 3.3 13 BULK-bbb19c19
11857 Bulk Product 12852fca Books $15.82 273 0.2 65 BULK-fd9748d0
11858 Bulk Product bb994d9e Electronics $810.10 355 1.4 72 BULK-1ab5f5d8
11859 Bulk Product af0ace7a Sports & Outdoors $28.22 380 1.1 40 BULK-ce919e9a
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