Efficient pagination using OFFSET-FETCH on SQL Server.
| ID | Name | Category | Price | Stock | Rating | Reviews | SKU |
|---|---|---|---|---|---|---|---|
| 24385 | Bulk Product 369487aa | Clothing | $763.83 | 318 | ★ 3.8 | 56 | BULK-db0f17fa |
| 24386 | Bulk Product d7f27d6a | Home & Garden | $130.45 | 201 | ★ 4.2 | 36 | BULK-d3a4d11b |
| 24387 | Bulk Product fbb06021 | Books | $799.98 | 429 | ★ 3.0 | 6 | BULK-e7dde212 |
| 24388 | Bulk Product dec2113c | Sports & Outdoors | $829.64 | 48 | ★ 3.5 | 76 | BULK-e19bede2 |
| 24389 | Bulk Product ac75168b | Home & Garden | $35.83 | 83 | ★ 0.4 | 12 | BULK-bfdf8081 |
| 24390 | Bulk Product a335c77d | Clothing | $24.92 | 158 | ★ 3.6 | 38 | BULK-f16af667 |
| 24391 | Bulk Product 7a6dbc70 | Books | $340.82 | 463 | ★ 1.5 | 86 | BULK-a059da30 |
| 24392 | Bulk Product 1939a975 | Home & Garden | $118.91 | 385 | ★ 0.6 | 99 | BULK-9b9b7e23 |
| 24393 | Bulk Product 70143272 | Electronics | $684.04 | 202 | ★ 3.3 | 49 | BULK-425c00c8 |
| 24394 | Bulk Product 04b4c0d1 | Clothing | $405.22 | 340 | ★ 1.5 | 20 | BULK-5579e29b |
| 24395 | Bulk Product 80051688 | Clothing | $632.48 | 393 | ★ 2.7 | 86 | BULK-9d4fcb94 |
| 24396 | Bulk Product 48e44be0 | Sports & Outdoors | $853.94 | 406 | ★ 0.5 | 63 | BULK-beac7987 |
| 24397 | Bulk Product 4d6a1e1d | Sports & Outdoors | $803.29 | 373 | ★ 1.1 | 75 | BULK-fbd5b0e0 |
| 24398 | Bulk Product 9084c353 | Clothing | $632.70 | 286 | ★ 4.1 | 22 | BULK-251f6d79 |
| 24399 | Bulk Product a4b89237 | Home & Garden | $333.42 | 467 | ★ 2.8 | 44 | BULK-dde526ce |
| 24400 | Bulk Product 8379eda2 | Sports & Outdoors | $302.10 | 419 | ★ 0.6 | 64 | BULK-a0636f77 |
| 24401 | Bulk Product 351cf4e8 | Toys & Games | $49.24 | 203 | ★ 1.8 | 82 | BULK-0c7d7b0c |
| 24402 | Bulk Product 94c33ca9 | Books | $468.09 | 348 | ★ 3.2 | 11 | BULK-e1966a77 |
| 24403 | Bulk Product 8d13544f | Toys & Games | $850.15 | 312 | ★ 4.3 | 13 | BULK-c6229300 |
| 24404 | Bulk Product 7527ea67 | Home & Garden | $759.38 | 267 | ★ 0.2 | 37 | BULK-9a45df7f |
| 24405 | Bulk Product a66bfe41 | Toys & Games | $419.45 | 59 | ★ 2.3 | 74 | BULK-93a2800b |
| 24406 | Bulk Product 372d0fae | Sports & Outdoors | $892.73 | 310 | ★ 4.6 | 1 | BULK-3959a26f |
| 24407 | Bulk Product 800a5c33 | Electronics | $712.67 | 303 | ★ 0.8 | 81 | BULK-b1855345 |
| 24408 | Bulk Product a87873df | Toys & Games | $787.87 | 431 | ★ 1.2 | 92 | BULK-3f45e0c2 |
| 24409 | Bulk Product 8759a64a | Electronics | $421.00 | 450 | ★ 2.1 | 77 | BULK-38c5da88 |
// 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
};
}