Efficient pagination using OFFSET-FETCH on SQL Server.
| ID | Name | Category | Price | Stock | Rating | Reviews | SKU |
|---|---|---|---|---|---|---|---|
| 13285 | Bulk Product a119b194 | Books | $720.71 | 71 | ★ 3.2 | 69 | BULK-43773f95 |
| 13286 | Bulk Product 8f0938d6 | Clothing | $531.47 | 189 | ★ 0.7 | 2 | BULK-70429f1b |
| 13287 | Bulk Product 18836962 | Toys & Games | $520.82 | 262 | ★ 2.1 | 87 | BULK-613e2c74 |
| 13288 | Bulk Product 36236863 | Home & Garden | $49.52 | 419 | ★ 1.6 | 57 | BULK-c3f7d474 |
| 13289 | Bulk Product 905b46d8 | Books | $557.61 | 56 | ★ 0.9 | 49 | BULK-f62e6fef |
| 13290 | Bulk Product 9194fa7c | Clothing | $576.40 | 246 | ★ 3.1 | 91 | BULK-aced9b27 |
| 13291 | Bulk Product 006d8cf5 | Sports & Outdoors | $787.15 | 273 | ★ 4.1 | 88 | BULK-ba2d7f01 |
| 13292 | Bulk Product 329f5382 | Home & Garden | $106.68 | 21 | ★ 3.0 | 12 | BULK-24e00fdf |
| 13293 | Bulk Product 9491e85c | Toys & Games | $812.16 | 17 | ★ 4.0 | 28 | BULK-74684a1e |
| 13294 | Bulk Product 2934267e | Sports & Outdoors | $335.08 | 454 | ★ 1.0 | 49 | BULK-3ae4017c |
| 13295 | Bulk Product cbbf2dee | Sports & Outdoors | $987.21 | 413 | ★ 1.1 | 5 | BULK-a9353819 |
| 13296 | Bulk Product 25cba54b | Clothing | $436.91 | 137 | ★ 2.0 | 90 | BULK-af800b63 |
| 13297 | Bulk Product 5b97f9e5 | Books | $498.95 | 423 | ★ 4.0 | 82 | BULK-2155b9c0 |
| 13298 | Bulk Product d862169e | Toys & Games | $19.71 | 414 | ★ 1.0 | 19 | BULK-05d13b5b |
| 13299 | Bulk Product cf256f7f | Home & Garden | $373.05 | 214 | ★ 4.2 | 0 | BULK-251e6823 |
| 13300 | Bulk Product a4eef6bc | Toys & Games | $279.09 | 215 | ★ 3.8 | 64 | BULK-09419b7c |
| 13301 | Bulk Product bdb2178e | Clothing | $980.82 | 431 | ★ 0.9 | 42 | BULK-3c93d12d |
| 13302 | Bulk Product 2db36298 | Home & Garden | $942.41 | 338 | ★ 1.1 | 19 | BULK-9124d595 |
| 13303 | Bulk Product eae92a5b | Books | $137.19 | 470 | ★ 3.8 | 39 | BULK-9e726162 |
| 13304 | Bulk Product 1fb3ee32 | Home & Garden | $967.51 | 258 | ★ 1.2 | 2 | BULK-710d244b |
| 13305 | Bulk Product 61d822d1 | Toys & Games | $99.86 | 446 | ★ 2.0 | 81 | BULK-3070eeaf |
| 13306 | Bulk Product afd29d25 | Toys & Games | $505.89 | 15 | ★ 0.5 | 2 | BULK-1186324c |
| 13307 | Bulk Product 4f69dd17 | Books | $278.44 | 449 | ★ 0.1 | 88 | BULK-2dc20363 |
| 13308 | Bulk Product 72326e65 | Home & Garden | $322.96 | 149 | ★ 0.0 | 32 | BULK-c5cfea50 |
| 13309 | Bulk Product 2b6d0049 | Clothing | $841.01 | 135 | ★ 0.7 | 95 | BULK-e2bb4435 |
// 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
};
}