Efficient pagination using OFFSET-FETCH on SQL Server.
| ID | Name | Category | Price | Stock | Rating | Reviews | SKU |
|---|---|---|---|---|---|---|---|
| 12510 | Bulk Product 782c8d45 | Sports & Outdoors | $750.72 | 465 | ★ 1.5 | 49 | BULK-2b2cf286 |
| 12511 | Bulk Product d262a78e | Books | $651.40 | 315 | ★ 3.5 | 91 | BULK-72f3a8cd |
| 12512 | Bulk Product fc948ae6 | Toys & Games | $85.24 | 473 | ★ 1.9 | 69 | BULK-4bb18223 |
| 12513 | Bulk Product 3d724057 | Toys & Games | $337.33 | 110 | ★ 2.1 | 32 | BULK-542436c9 |
| 12514 | Bulk Product 93bfbade | Books | $773.28 | 484 | ★ 1.3 | 23 | BULK-3ea4e0f6 |
| 12515 | Bulk Product ae4d3c7f | Home & Garden | $49.71 | 270 | ★ 2.4 | 78 | BULK-dcdb82e7 |
| 12516 | Bulk Product 05596f2b | Toys & Games | $795.86 | 388 | ★ 0.3 | 26 | BULK-1c0fd0eb |
| 12517 | Bulk Product f09f9b21 | Toys & Games | $299.34 | 74 | ★ 4.5 | 94 | BULK-8a45e4ea |
| 12518 | Bulk Product 19f98773 | Books | $345.42 | 477 | ★ 2.8 | 45 | BULK-e6105750 |
| 12519 | Bulk Product f0991448 | Sports & Outdoors | $867.87 | 361 | ★ 1.4 | 1 | BULK-897cc9ea |
| 12520 | Bulk Product fddb07db | Electronics | $281.44 | 320 | ★ 3.7 | 98 | BULK-df9dcfa4 |
| 12521 | Bulk Product 5026d9d0 | Home & Garden | $84.79 | 81 | ★ 2.7 | 24 | BULK-faaa180b |
| 12522 | Bulk Product bf11e437 | Electronics | $10.76 | 197 | ★ 1.9 | 21 | BULK-532fed9e |
| 12523 | Bulk Product 1e340c84 | Clothing | $473.57 | 325 | ★ 2.0 | 8 | BULK-660cf341 |
| 12524 | Bulk Product 2bf1dd4e | Books | $435.95 | 407 | ★ 1.4 | 16 | BULK-0efc1b54 |
| 12525 | Bulk Product 37baae48 | Sports & Outdoors | $617.36 | 254 | ★ 3.6 | 10 | BULK-9422a48a |
| 12526 | Bulk Product ad8bd0dc | Electronics | $542.07 | 215 | ★ 0.9 | 39 | BULK-4b3d45fd |
| 12527 | Bulk Product 8a4c9d20 | Books | $598.15 | 479 | ★ 2.7 | 60 | BULK-15f96605 |
| 12528 | Bulk Product a0b6ddbb | Toys & Games | $413.38 | 204 | ★ 0.4 | 8 | BULK-b8c4ec4f |
| 12529 | Bulk Product 763a395a | Electronics | $927.89 | 343 | ★ 3.9 | 97 | BULK-e58eee6b |
| 12530 | Bulk Product 670034be | Books | $1,008.77 | 251 | ★ 4.0 | 91 | BULK-26b46b9b |
| 12531 | Bulk Product f6452ede | Toys & Games | $322.46 | 193 | ★ 0.9 | 23 | BULK-78b12b58 |
| 12532 | Bulk Product d6c24a68 | Books | $972.92 | 490 | ★ 3.6 | 86 | BULK-000f95c8 |
| 12533 | Bulk Product c3049751 | Toys & Games | $530.42 | 325 | ★ 4.3 | 2 | BULK-9c1935e2 |
| 12534 | Bulk Product 6b88c890 | Books | $897.81 | 396 | ★ 1.1 | 50 | BULK-14532cdb |
// 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
};
}