👉🏼 Click here to Join I ❤️ .NET WhatsApp Channel to get 🔔 notified about new articles and other updates.
Using LINQ Skip to Select Specific Data

Using LINQ Skip to Select Specific Data

Author - Abdul Rahman (Bhai)

LINQ

26 Articles

Improve

Table of Contents

  1. What we gonna do?
  2. Why we gonna do?
  3. How we gonna do?
  4. Summary

What we gonna do?

In this article, let's learn about how to use Skip and SkipWhile in LINQ in .NET.

Note: If you have not done so already, I recommend you read the article on Using LINQ Take to Select Specific Data in Collections.

We can perform skip and select specific piece of data from beginning of a collection using LINQ. We're going to use Skip() and SkipWhile() methods. Let's take a look at each of these methods and how they work.

Why we gonna do?

When listing the items, its not always possible to list all the items. Sometimes we need to limit and partition the items from database or need a pagination in UI to display subset of records for better UX (User Experience) as not all the datas are required everytime unless its a reporting task. So Skip(n) allows you to skip specific items from beginning of collection. It skips number of items given as input and returns records after that number.

How we gonna do?

Perform partition using Skip


List<Product> products = GetProducts();

//Method Syntax
List<Product> partitionedProducts = products
                                    .Skip(2)
                                    .ToList();
                    
//Query Syntax
List<Product> partitionedProducts = (from product in products select product)
                                    .Skip(2)
                                    .ToList();
        
Demo Space

Perform conditional partition using SkipWhile

We can also extract data conditionally using SkipWhile while the condition evaluates to true. Note that Enumeration stops when the predicate function returns false for an element or when source contains no more elements.


List<Product> products = GetProducts();

//Method Syntax
List<Product> partitionedProducts = products
                                    .SkipWhile(product => product.Name.StartsWith("P"))
                                    .ToList();
                    
//Query Syntax
List<Product> partitionedProducts = (from product in products select product)
                                    .SkipWhile(product => product.Name.StartsWith("P"))
                                    .ToList();
        
Demo Space

Summary

In this article we learn't how to locate partition and extract specific data within collection using Skip and SkipWhile. We also saw how we can pass an condition to partition data. Skip() can be used together with Take() to implement pagination. All these can be used with any IEnumerable or IQueryable types.

👉🏼 Click here to Join I ❤️ .NET WhatsApp Channel to get 🔔 notified about new articles and other updates.
  • LINQ
  • Skip
  • SkipWhile
  • Partition