<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FC_Sharp%2FLINQ%2Fwhere</id>
		<title>Csharp/C Sharp/LINQ/where - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://nfex.ru/index.php?action=history&amp;feed=atom&amp;title=Csharp%2FC_Sharp%2FLINQ%2Fwhere"/>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/C_Sharp/LINQ/where&amp;action=history"/>
		<updated>2026-04-30T02:22:55Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/C_Sharp/LINQ/where&amp;diff=504&amp;oldid=prev</id>
		<title> в 15:31, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/C_Sharp/LINQ/where&amp;diff=504&amp;oldid=prev"/>
				<updated>2010-05-26T15:31:18Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 15:31, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://nfex.ru/index.php?title=Csharp/C_Sharp/LINQ/where&amp;diff=505&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://nfex.ru/index.php?title=Csharp/C_Sharp/LINQ/where&amp;diff=505&amp;oldid=prev"/>
				<updated>2010-05-26T11:38:44Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==A Query Using the Standard Dot Notation Syntax==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
&lt;br /&gt;
using System;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        string[] names = { &amp;quot;A1&amp;quot;, &amp;quot;B123&amp;quot;, &amp;quot;C123123&amp;quot;, &amp;quot;E&amp;quot;, &amp;quot;W&amp;quot; };&lt;br /&gt;
        IEnumerable&amp;lt;string&amp;gt; sequence = names&lt;br /&gt;
         .Where(n =&amp;gt; n.Length &amp;lt; 6)&lt;br /&gt;
         .Select(n =&amp;gt; n);&lt;br /&gt;
        foreach (string name in sequence) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;{0}&amp;quot;, name);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Assign the loop variable to another variable declared inside the statement block==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        IEnumerable&amp;lt;char&amp;gt; vowels = &amp;quot;aeiou&amp;quot;;&lt;br /&gt;
        IEnumerator&amp;lt;char&amp;gt; rator = vowels.GetEnumerator();&lt;br /&gt;
        IEnumerable&amp;lt;char&amp;gt; query = &amp;quot;Not what you might expect&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
        foreach (char vowel in &amp;quot;aeiou&amp;quot;) {&lt;br /&gt;
            char temp = vowel;&lt;br /&gt;
            query = query.Where(c =&amp;gt; c != temp);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Filtered: prints the name of each element of an integer array that is less than 5==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Text;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        int[] numbers = { 5, 4, 1, 3};&lt;br /&gt;
        string[] digits = { &amp;quot;zero&amp;quot;, &amp;quot;one&amp;quot;, &amp;quot;two&amp;quot;, &amp;quot;three&amp;quot;};&lt;br /&gt;
        var lowNums =&lt;br /&gt;
            from n in numbers&lt;br /&gt;
            where n &amp;lt; 5&lt;br /&gt;
            select digits[n];&lt;br /&gt;
        Console.WriteLine(&amp;quot;Numbers &amp;lt; 5:&amp;quot;);&lt;br /&gt;
        foreach (var num in lowNums) {&lt;br /&gt;
            Console.WriteLine(num);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Filter string by its length==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
class LinqDemo {&lt;br /&gt;
    static void Main() {&lt;br /&gt;
        string[] names = { &amp;quot;Tom&amp;quot;, &amp;quot;Dick&amp;quot;, &amp;quot;Harry&amp;quot; };&lt;br /&gt;
&lt;br /&gt;
        IEnumerable&amp;lt;string&amp;gt; filteredNames = names.Where(n =&amp;gt; n.Length &amp;gt;= 4);&lt;br /&gt;
        foreach (string name in filteredNames) Console.Write(name + &amp;quot;|&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==prints strings where each element has the second letter &amp;quot;i&amp;quot;.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Text;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        string[] digits = { &amp;quot;ziro&amp;quot;, &amp;quot;one&amp;quot;, &amp;quot;two&amp;quot;, &amp;quot;three&amp;quot;};&lt;br /&gt;
        var reversedIDigits = (&lt;br /&gt;
            from d in digits&lt;br /&gt;
            where d[1] == &amp;quot;i&amp;quot;&lt;br /&gt;
            select d)&lt;br /&gt;
            .Reverse();&lt;br /&gt;
        foreach (var d in reversedIDigits) {&lt;br /&gt;
            Console.WriteLine(d);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Query string value by String.StartsWith==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        string[] presidents = {&amp;quot;Ad&amp;quot;, &amp;quot;Ar&amp;quot;, &amp;quot;Bu&amp;quot;, &amp;quot;B&amp;quot;, &amp;quot;C&amp;quot;, &amp;quot;C&amp;quot;};&lt;br /&gt;
        string president = presidents.Where(p =&amp;gt; p.StartsWith(&amp;quot;Ad&amp;quot;)).First();&lt;br /&gt;
        Console.WriteLine(president);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Query Using the Query Expression Syntax==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
&lt;br /&gt;
using System;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        string[] names = { &amp;quot;A123123&amp;quot;, &amp;quot;B123&amp;quot;, &amp;quot;C123123&amp;quot;, &amp;quot;E123&amp;quot;, &amp;quot;W&amp;quot; };&lt;br /&gt;
        IEnumerable&amp;lt;string&amp;gt; sequence = from n in names&lt;br /&gt;
                                       where n.Length &amp;lt; 6&lt;br /&gt;
                                       select n;&lt;br /&gt;
        foreach (string name in sequence) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;{0}&amp;quot;, name);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Query with an Exception==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
&lt;br /&gt;
using System;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        string[] presidents = {&amp;quot;AAAA&amp;quot;, &amp;quot;aaaa&amp;quot;, &amp;quot;bacDert&amp;quot;, &amp;quot;B1234&amp;quot;, &amp;quot;Carter&amp;quot;};&lt;br /&gt;
        IEnumerable&amp;lt;string&amp;gt; items = presidents.Where(s =&amp;gt; Char.IsLower(s[4]));&lt;br /&gt;
        Console.WriteLine(&amp;quot;After the query.&amp;quot;);&lt;br /&gt;
        foreach (string item in items)&lt;br /&gt;
            Console.WriteLine(item);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==To remove all vowels from a string.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        IEnumerable&amp;lt;char&amp;gt; query = &amp;quot;Not what you might expect&amp;quot;;&lt;br /&gt;
        query = query.Where(c =&amp;gt; c != &amp;quot;a&amp;quot;);&lt;br /&gt;
        query = query.Where(c =&amp;gt; c != &amp;quot;e&amp;quot;);&lt;br /&gt;
        query = query.Where(c =&amp;gt; c != &amp;quot;i&amp;quot;);&lt;br /&gt;
        query = query.Where(c =&amp;gt; c != &amp;quot;o&amp;quot;);&lt;br /&gt;
        query = query.Where(c =&amp;gt; c != &amp;quot;u&amp;quot;);&lt;br /&gt;
        foreach (char c in query) Console.Write(c); &lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Two where clauses==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
class Employee {&lt;br /&gt;
    int _id;&lt;br /&gt;
    int _idRole;&lt;br /&gt;
    string _lastName;&lt;br /&gt;
    string _firstName;&lt;br /&gt;
    public int ID {&lt;br /&gt;
        get { return _id; }&lt;br /&gt;
        set { _id = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public int IDRole {&lt;br /&gt;
        get { return _idRole; }&lt;br /&gt;
        set { _idRole = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public string LastName {&lt;br /&gt;
        get { return _lastName; }&lt;br /&gt;
        set { _lastName = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public string FirstName {&lt;br /&gt;
        get { return _firstName; }&lt;br /&gt;
        set { _firstName = value; }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
class Salary {&lt;br /&gt;
    int _id;&lt;br /&gt;
    int _year;&lt;br /&gt;
    double _salary;&lt;br /&gt;
    public int ID {&lt;br /&gt;
        get { return _id; }&lt;br /&gt;
        set { _id = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public int Year {&lt;br /&gt;
        get { return _year; }&lt;br /&gt;
        set { _year = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public double SalaryPaid {&lt;br /&gt;
        get { return _salary; }&lt;br /&gt;
        set { _salary = value; }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        List&amp;lt;Employee&amp;gt; people = new List&amp;lt;Employee&amp;gt; {&lt;br /&gt;
              new Employee  { ID = 1, IDRole = 1, LastName = &amp;quot;A&amp;quot;, FirstName = &amp;quot;B&amp;quot;},&lt;br /&gt;
              new Employee  { ID = 2, IDRole = 2, LastName = &amp;quot;G&amp;quot;, FirstName = &amp;quot;T&amp;quot;}&lt;br /&gt;
            };&lt;br /&gt;
        List&amp;lt;Salary&amp;gt; salaries = new List&amp;lt;Salary&amp;gt; {&lt;br /&gt;
               new Salary { ID = 1, Year = 2004, SalaryPaid = 10000.00 },&lt;br /&gt;
               new Salary { ID = 1, Year = 2005, SalaryPaid = 15000.00 },&lt;br /&gt;
               new Salary { ID = 1, Year = 2005, SalaryPaid = 15000.00 }&lt;br /&gt;
            };&lt;br /&gt;
        IEnumerable&amp;lt;Salary&amp;gt; q = from p in people&lt;br /&gt;
                                where p.ID == 1&lt;br /&gt;
                                from s in salaries&lt;br /&gt;
                                where s.ID == p.ID&lt;br /&gt;
                                select s;&lt;br /&gt;
&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use &amp;amp;&amp;amp; in where clause==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Text;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        List&amp;lt;Product&amp;gt; products = GetProductList();&lt;br /&gt;
        var expensiveInStockProducts =&lt;br /&gt;
            from p in products&lt;br /&gt;
            where p.UnitsInStock &amp;gt; 0 &amp;amp;&amp;amp; p.UnitPrice &amp;gt; 3.00M&lt;br /&gt;
            select p;&lt;br /&gt;
        foreach (var product in expensiveInStockProducts) {&lt;br /&gt;
            Console.WriteLine(product.ProductName);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    static List&amp;lt;Product&amp;gt; GetProductList() {&lt;br /&gt;
        List&amp;lt;Product&amp;gt; empTree = new List&amp;lt;Product&amp;gt;();&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;A&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 12, UnitsInStock = 5, Total = 36, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;B&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 2, UnitsInStock = 4, Total = 35, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;C&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 112, UnitsInStock = 3, Total = 34, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;D&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 112, UnitsInStock = 0, Total = 33, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;E&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 1112, UnitsInStock = 2, Total = 32, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;F&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 11112, UnitsInStock = 0, Total = 31, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        return empTree;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
class Product : IComparable&amp;lt;Product&amp;gt; {&lt;br /&gt;
    public string ProductName { get; set; }&lt;br /&gt;
    public string Category { get; set; }&lt;br /&gt;
    public int UnitPrice { get; set; }&lt;br /&gt;
    public int UnitsInStock { get; set; }&lt;br /&gt;
    public int Total { get; set; }&lt;br /&gt;
    public DateTime OrderDate { get; set; }&lt;br /&gt;
    public int Id { get; set; }&lt;br /&gt;
    public override string ToString() {&lt;br /&gt;
        return String.Format(&amp;quot;Id: {0}, Name: {1} , Category: {3}&amp;quot;, this.Id, this.ProductName, this.Category);&lt;br /&gt;
    }&lt;br /&gt;
    int IComparable&amp;lt;Product&amp;gt;.rupareTo(Product other) {&lt;br /&gt;
        if (other == null)&lt;br /&gt;
            return 1;&lt;br /&gt;
        if (this.Id &amp;gt; other.Id)&lt;br /&gt;
            return 1;&lt;br /&gt;
        if (this.Id &amp;lt; other.Id)&lt;br /&gt;
            return -1;&lt;br /&gt;
        return 0;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use string method in where clause==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
&lt;br /&gt;
using System;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        string[] greetings = { &amp;quot;hello world&amp;quot;, &amp;quot;hello LINQ&amp;quot;, &amp;quot;hello&amp;quot; };&lt;br /&gt;
        var items =&lt;br /&gt;
         from s in greetings&lt;br /&gt;
         where s.EndsWith(&amp;quot;LINQ&amp;quot;)&lt;br /&gt;
         select s;&lt;br /&gt;
        foreach (var item in items)&lt;br /&gt;
            Console.WriteLine(item);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==use where clause in a while loop==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        IEnumerable&amp;lt;char&amp;gt; vowels = &amp;quot;aeiou&amp;quot;;&lt;br /&gt;
        IEnumerator&amp;lt;char&amp;gt; rator = vowels.GetEnumerator();&lt;br /&gt;
        IEnumerable&amp;lt;char&amp;gt; query = &amp;quot;Not what you might expect&amp;quot;;&lt;br /&gt;
        char vowel;&lt;br /&gt;
        while (rator.MoveNext()) {&lt;br /&gt;
            vowel = rator.Current;&lt;br /&gt;
            query = query.Where(c =&amp;gt; c != vowel);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use where to filer object list==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Text;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        List&amp;lt;Product&amp;gt; products = GetProductList();&lt;br /&gt;
        var soldOutProducts =&lt;br /&gt;
            from p in products&lt;br /&gt;
            where p.UnitsInStock == 0&lt;br /&gt;
            select p;&lt;br /&gt;
        Console.WriteLine(&amp;quot;Sold out products:&amp;quot;);&lt;br /&gt;
        foreach (var product in soldOutProducts) {&lt;br /&gt;
            Console.WriteLine(&amp;quot;{0} is sold out!&amp;quot;, product.ProductName);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    static List&amp;lt;Product&amp;gt; GetProductList() {&lt;br /&gt;
        List&amp;lt;Product&amp;gt; empTree = new List&amp;lt;Product&amp;gt;();&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;A&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 12, UnitsInStock = 5, Total = 36, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;B&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 2, UnitsInStock = 4, Total = 35, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;C&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 112, UnitsInStock = 3, Total = 34, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;D&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 112, UnitsInStock = 0, Total = 33, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;E&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 1112, UnitsInStock = 2, Total = 32, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        empTree.Add(new Product { ProductName = &amp;quot;F&amp;quot;, Category = &amp;quot;O&amp;quot;, UnitPrice = 11112, UnitsInStock = 0, Total = 31, OrderDate = new DateTime(2005, 1, 1), Id = 1 });&lt;br /&gt;
        return empTree;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
class Product : IComparable&amp;lt;Product&amp;gt; {&lt;br /&gt;
    public string ProductName { get; set; }&lt;br /&gt;
    public string Category { get; set; }&lt;br /&gt;
    public int UnitPrice { get; set; }&lt;br /&gt;
    public int UnitsInStock { get; set; }&lt;br /&gt;
    public int Total { get; set; }&lt;br /&gt;
    public DateTime OrderDate { get; set; }&lt;br /&gt;
    public int Id { get; set; }&lt;br /&gt;
    public override string ToString() {&lt;br /&gt;
        return String.Format(&amp;quot;Id: {0}, Name: {1} , Category: {3}&amp;quot;, this.Id, this.ProductName, this.Category);&lt;br /&gt;
    }&lt;br /&gt;
    int IComparable&amp;lt;Product&amp;gt;.rupareTo(Product other) {&lt;br /&gt;
        if (other == null)&lt;br /&gt;
            return 1;&lt;br /&gt;
        if (this.Id &amp;gt; other.Id)&lt;br /&gt;
            return 1;&lt;br /&gt;
        if (this.Id &amp;lt; other.Id)&lt;br /&gt;
            return -1;&lt;br /&gt;
        return 0;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==where clause==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
using System.Text;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Reflection;&lt;br /&gt;
class Person {&lt;br /&gt;
    int _id;&lt;br /&gt;
    int _idRole;&lt;br /&gt;
    string _lastName;&lt;br /&gt;
    string _firstName;&lt;br /&gt;
    public int ID {&lt;br /&gt;
        get { return _id; }&lt;br /&gt;
        set { _id = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public int IDRole {&lt;br /&gt;
        get { return _idRole; }&lt;br /&gt;
        set { _idRole = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public string LastName {&lt;br /&gt;
        get { return _lastName; }&lt;br /&gt;
        set { _lastName = value; }&lt;br /&gt;
    }&lt;br /&gt;
    public string FirstName {&lt;br /&gt;
        get { return _firstName; }&lt;br /&gt;
        set { _firstName = value; }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
class Program {&lt;br /&gt;
    static void Main(string[] args) {&lt;br /&gt;
        List&amp;lt;Person&amp;gt; people = new List&amp;lt;Person&amp;gt; {&lt;br /&gt;
              new Person  { ID = 1, IDRole = 1, LastName = &amp;quot;A&amp;quot;, FirstName = &amp;quot;B&amp;quot;},&lt;br /&gt;
              new Person  { ID = 2, IDRole = 2, LastName = &amp;quot;G&amp;quot;, FirstName = &amp;quot;T&amp;quot;},&lt;br /&gt;
              new Person  { ID = 3, IDRole = 2, LastName = &amp;quot;G&amp;quot;, FirstName = &amp;quot;M&amp;quot;},&lt;br /&gt;
              new Person  { ID = 4, IDRole = 3, LastName = &amp;quot;C&amp;quot;, FirstName = &amp;quot;G&amp;quot;}&lt;br /&gt;
            };&lt;br /&gt;
        var query = people.Where((p, index) =&amp;gt; p.IDRole == index);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Where clause with string method and return IEnumerable object==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
&lt;br /&gt;
        string[] presidents = {&amp;quot;AA&amp;quot;, &amp;quot;A&amp;quot;, &amp;quot;AAA&amp;quot;, &amp;quot;B&amp;quot;, &amp;quot;Ca&amp;quot;, &amp;quot;C&amp;quot;};&lt;br /&gt;
        IEnumerable&amp;lt;string&amp;gt; items = presidents.Where(p =&amp;gt; p.StartsWith(&amp;quot;A&amp;quot;));&lt;br /&gt;
        foreach (string item in items)&lt;br /&gt;
            Console.WriteLine(item);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Where Prototype==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;csharp&amp;quot;&amp;gt; &lt;br /&gt;
using System;&lt;br /&gt;
using System.Linq;&lt;br /&gt;
using System.Collections;&lt;br /&gt;
using System.Collections.Generic;&lt;br /&gt;
public class MainClass {&lt;br /&gt;
    public static void Main() {&lt;br /&gt;
        string[] presidents = {&amp;quot;A&amp;quot;, &amp;quot;Ar&amp;quot;, &amp;quot;B&amp;quot;, &amp;quot;Bu&amp;quot;, &amp;quot;C&amp;quot;, &amp;quot;Cleveland&amp;quot;};&lt;br /&gt;
        IEnumerable&amp;lt;string&amp;gt; sequence = presidents.Where(p =&amp;gt; p.StartsWith(&amp;quot;C&amp;quot;));&lt;br /&gt;
        foreach (string s in sequence)&lt;br /&gt;
            Console.WriteLine(&amp;quot;{0}&amp;quot;, s);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>