Efficient pagination using OFFSET-FETCH on SQL Server.
| ID | Name | Category | Price | Stock | Rating | Reviews | SKU |
|---|---|---|---|---|---|---|---|
| 7635 | Bulk Product 49ae11af | Sports & Outdoors | $370.64 | 331 | ★ 4.5 | 3 | BULK-30bd1283 |
| 7636 | Bulk Product 4b2cdb93 | Clothing | $922.46 | 462 | ★ 3.6 | 72 | BULK-58879d87 |
| 7637 | Bulk Product 98e90539 | Sports & Outdoors | $312.41 | 367 | ★ 0.9 | 21 | BULK-17bc9780 |
| 7638 | Bulk Product 2a545256 | Toys & Games | $727.70 | 18 | ★ 0.4 | 54 | BULK-a8382986 |
| 7639 | Bulk Product 7040b61c | Sports & Outdoors | $829.66 | 334 | ★ 3.3 | 67 | BULK-2bbb08ec |
| 7640 | Bulk Product 363f0071 | Home & Garden | $207.27 | 113 | ★ 1.5 | 24 | BULK-e20e5bad |
| 7641 | Bulk Product 38364d3b | Sports & Outdoors | $380.60 | 103 | ★ 2.3 | 64 | BULK-ac1e0b3d |
| 7642 | Bulk Product 73e2098f | Toys & Games | $311.31 | 84 | ★ 3.4 | 96 | BULK-ee7361d5 |
| 7643 | Bulk Product 68b6c099 | Electronics | $37.05 | 428 | ★ 2.4 | 53 | BULK-8ccee8df |
| 7644 | Bulk Product a4628353 | Clothing | $630.06 | 41 | ★ 2.3 | 11 | BULK-f223e6a0 |
| 7645 | Bulk Product 4354bedb | Toys & Games | $561.00 | 2 | ★ 5.0 | 57 | BULK-1e71ecd2 |
| 7646 | Bulk Product 0458f5c4 | Books | $101.48 | 420 | ★ 4.0 | 14 | BULK-48ad7636 |
| 7647 | Bulk Product 0cd0c7ba | Clothing | $351.09 | 314 | ★ 4.2 | 47 | BULK-2362ee9d |
| 7648 | Bulk Product 248594f5 | Electronics | $369.85 | 305 | ★ 4.4 | 68 | BULK-8fd34c24 |
| 7649 | Bulk Product 6aa11051 | Books | $17.80 | 348 | ★ 0.1 | 96 | BULK-268b425d |
| 7650 | Bulk Product 93f010ab | Home & Garden | $937.16 | 143 | ★ 1.5 | 94 | BULK-09f2fb81 |
| 7651 | Bulk Product 868c858e | Home & Garden | $692.54 | 161 | ★ 0.5 | 21 | BULK-dc19e7cb |
| 7652 | Bulk Product 158f8ba0 | Clothing | $538.85 | 229 | ★ 1.9 | 14 | BULK-cdf267e8 |
| 7653 | Bulk Product b3e6ca12 | Toys & Games | $60.64 | 378 | ★ 4.2 | 59 | BULK-6f51ae3d |
| 7654 | Bulk Product a2117790 | Home & Garden | $76.81 | 9 | ★ 0.5 | 19 | BULK-90a429b9 |
| 7655 | Bulk Product f2fe0680 | Electronics | $930.97 | 276 | ★ 5.0 | 65 | BULK-94b08f49 |
| 7656 | Bulk Product 170d2510 | Books | $632.34 | 383 | ★ 1.0 | 5 | BULK-fcaf28a7 |
| 7657 | Bulk Product f677c609 | Home & Garden | $730.71 | 333 | ★ 4.6 | 68 | BULK-08d64d7a |
| 7658 | Bulk Product df8ec88d | Clothing | $448.50 | 429 | ★ 4.3 | 77 | BULK-b28a86eb |
| 7659 | Bulk Product 0b59528a | Home & Garden | $202.78 | 494 | ★ 4.7 | 36 | BULK-93f91018 |
// 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
};
}