Efficient pagination using OFFSET-FETCH on SQL Server.
| ID | Name | Category | Price | Stock | Rating | Reviews | SKU |
|---|---|---|---|---|---|---|---|
| 8210 | Bulk Product 8a33dac7 | Home & Garden | $271.73 | 259 | ★ 4.7 | 50 | BULK-fc513480 |
| 8211 | Bulk Product f8b6ce21 | Books | $530.67 | 109 | ★ 1.1 | 89 | BULK-45775170 |
| 8212 | Bulk Product 9ffdd0d3 | Sports & Outdoors | $785.45 | 119 | ★ 2.7 | 26 | BULK-41fd8369 |
| 8213 | Bulk Product d9879c13 | Toys & Games | $600.00 | 219 | ★ 1.6 | 90 | BULK-cbc00057 |
| 8214 | Bulk Product 622480ac | Clothing | $363.06 | 250 | ★ 1.3 | 17 | BULK-9f1377e3 |
| 8215 | Bulk Product 4c322eb5 | Books | $471.96 | 388 | ★ 1.5 | 94 | BULK-42a2bcac |
| 8216 | Bulk Product eae6e25b | Electronics | $740.13 | 228 | ★ 3.1 | 17 | BULK-184d7116 |
| 8217 | Bulk Product fc2ef699 | Electronics | $111.80 | 273 | ★ 4.8 | 78 | BULK-d911afc4 |
| 8218 | Bulk Product 251912db | Books | $907.95 | 216 | ★ 1.0 | 37 | BULK-43bcbc9b |
| 8219 | Bulk Product 4ef9da5d | Electronics | $124.67 | 223 | ★ 0.7 | 96 | BULK-141343f7 |
| 8220 | Bulk Product 0d42c715 | Toys & Games | $893.93 | 320 | ★ 2.8 | 26 | BULK-eccb3b8e |
| 8221 | Bulk Product 7cd02c75 | Toys & Games | $616.08 | 5 | ★ 3.9 | 6 | BULK-8d23c57c |
| 8222 | Bulk Product 64537eba | Books | $275.89 | 164 | ★ 1.4 | 41 | BULK-ae449971 |
| 8223 | Bulk Product 23772b09 | Home & Garden | $394.43 | 10 | ★ 0.0 | 84 | BULK-510c050e |
| 8224 | Bulk Product f7516c7f | Toys & Games | $461.26 | 410 | ★ 0.8 | 67 | BULK-752c9025 |
| 8225 | Bulk Product 1c2258e5 | Sports & Outdoors | $79.43 | 357 | ★ 4.0 | 62 | BULK-3066dc7c |
| 8226 | Bulk Product a38d3bb0 | Clothing | $116.45 | 25 | ★ 0.4 | 5 | BULK-bc47da48 |
| 8227 | Bulk Product 1969ad25 | Toys & Games | $947.36 | 56 | ★ 4.5 | 60 | BULK-c098a392 |
| 8228 | Bulk Product 2272c87f | Toys & Games | $454.65 | 11 | ★ 4.9 | 93 | BULK-6d3ee791 |
| 8229 | Bulk Product b1b27b93 | Sports & Outdoors | $15.42 | 412 | ★ 0.6 | 86 | BULK-d8506684 |
| 8230 | Bulk Product 09d2ac77 | Books | $420.75 | 490 | ★ 1.1 | 35 | BULK-6a41df7f |
| 8231 | Bulk Product f0ef5712 | Clothing | $651.32 | 444 | ★ 3.6 | 10 | BULK-60f9dddf |
| 8232 | Bulk Product b0592980 | Home & Garden | $175.17 | 109 | ★ 2.1 | 22 | BULK-0ab82e4c |
| 8233 | Bulk Product 20b94a34 | Home & Garden | $105.63 | 178 | ★ 0.5 | 60 | BULK-5b000306 |
| 8234 | Bulk Product 327e37f0 | Sports & Outdoors | $369.38 | 417 | ★ 3.5 | 21 | BULK-03982119 |
// 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
};
}