Aracılığıyla paylaş


Nasıl yapılır: bir ArrayList LINQ ile sorgulama

Kullanırken LINQ sorgu olmayan genel IEnumerable koleksiyonları gibi ArrayList, açıkça, derlemedeki belirli türde yansıtacak şekilde aralık değişken türünü bildirmeniz gerekir.Örneğin, bir ArrayList , Student nesneleri, sizin from yan tümcesi (C#) veya From yan tümcesi (Visual Basic) aþaðýdaki gibi görünmelidir:

// C#
var query = from Student s in arrList
... 
'Visual Basic
Dim query = From student As Student In arrList 
...

Aralık değişken türünü belirleyerek, her madde çevrim ArrayList için bir Student.

Arama için bir sorgu ifadesinde açıkça yazılı aralık değişkeninin kullanımına eşdeğerdir Cast<TResult> yöntemi.Cast<TResult>Belirtilen atama gerçekleştirilemiyorsa bir istisna atar.Cast<TResult>ve OfType<TResult> , genel olmayan üzerinde çalışan iki standart sorgu işlecini yöntemler IEnumerable türleri.De Visual Basic, açıkça çağırması gerekir Cast<TResult> yöntemi veri kaynağındaki belirli bir değişken türü emin olmak için.Daha fazla bilgi için bkz:Tür ilişkileri sorgu işlemlerinde (Visual Basic) ve Tür ilişkileri LINQ sorgu işlemlerinde (C#).

Örnek

Aşağıdaki örnek, basit bir sorgu üzerinden gösterir bir ArrayList.Bu örnek kod çağırdığında nesne başlatıcılar kullandığına dikkat edin Add yöntemi değildir, ancak bu bir gereklilik.

Imports System.Collections
Imports System.Linq

Module Module1

    Public Class Student
        Public Property FirstName As String
        Public Property LastName As String
        Public Property Scores As Integer()
    End Class

    Sub Main()

        Dim student1 As New Student With {.FirstName = "Svetlana", 
                                     .LastName = "Omelchenko", 
                                     .Scores = New Integer() {98, 92, 81, 60}}
        Dim student2 As New Student With {.FirstName = "Claire", 
                                    .LastName = "O'Donnell", 
                                    .Scores = New Integer() {75, 84, 91, 39}}
        Dim student3 As New Student With {.FirstName = "Cesar", 
                                    .LastName = "Garcia", 
                                    .Scores = New Integer() {97, 89, 85, 82}}
        Dim student4 As New Student With {.FirstName = "Sven", 
                                    .LastName = "Mortensen", 
                                    .Scores = New Integer() {88, 94, 65, 91}}

        Dim arrList As New ArrayList()
        arrList.Add(student1)
        arrList.Add(student2)
        arrList.Add(student3)
        arrList.Add(student4)

        ' Use an explicit type for non-generic collections
        Dim query = From student As Student In arrList 
                    Where student.Scores(0) > 95 
                    Select student

        For Each student As Student In query
            Console.WriteLine(student.LastName & ": " & student.Scores(0))
        Next
        ' Keep the console window open in debug mode.
        Console.WriteLine("Press any key to exit.")
        Console.ReadKey()
    End Sub

End Module
' Output:
'   Omelchenko: 98
'   Garcia: 97
using System;
using System.Collections;
using System.Linq;

namespace NonGenericLINQ
{
    public class Student
    {
        public string FirstName { get; set; }
        public string LastName { get; set; }
        public int[] Scores { get; set; }
    }

    class Program
    {
        static void Main(string[] args)
        {
            ArrayList arrList = new ArrayList();
            arrList.Add(
                new Student
                    {
                        FirstName = "Svetlana", LastName = "Omelchenko", Scores = new int[] { 98, 92, 81, 60 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Claire", LastName = "O’Donnell", Scores = new int[] { 75, 84, 91, 39 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Sven", LastName = "Mortensen", Scores = new int[] { 88, 94, 65, 91 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Cesar", LastName = "Garcia", Scores = new int[] { 97, 89, 85, 82 }
                    });

            var query = from Student student in arrList
                        where student.Scores[0] > 95
                        select student;

            foreach (Student s in query)
                Console.WriteLine(s.LastName + ": " + s.Scores[0]);

            // Keep the console window open in debug mode.
            Console.WriteLine("Press any key to exit.");
            Console.ReadKey();
        }
    }
}
/* Output: 
    Omelchenko: 98
    Garcia: 97
*/

Ayrıca bkz.

Kavramlar

LINQ nesnelere