مشاركة عبر


كيفية القيام بما يلي: استعلام ArrayList مع LINQ

عند استخدام LINQ لاستعلام مجموعات IEnumerable الغير عامة مثل ArrayList، يجب تعريف نوع متغير النطاق بوضوح ليعكس نوع محدد من الكائنات في المجموعة. على سبيل المثال، إذا كان لديك ArrayList من Student من الكائنات ، فقرة From الخاصة بك (#C) أو من عبارة (Visual Basic) يجب أن تبدو كما يلي:

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

عن طريق تحديد نوع متغير النطاق, أنت تحول كل عنصر في ArrayList إلى Student.

استخدام متغير النطاق المحدد النوع بوضوح في تعبير استعلام هو مكافئ لاستدعاء الأسلوب Cast<TResult>. Cast<TResult> يطرح ‏‏ استثناء إذا لا يمكن تنفيذ التحويل المحدد. Cast<TResult> و OfType<TResult> هما أسلوبا مشغل الاستعلامات القياسي اللذان يعملان أنواع IEnumerable غير عامة. في Visual Basic، يجب عليك استدعاء أسلوب Cast<TResult> بشكل صريح على مصدر البيانات للتأكد من نوع متغير نطاق المحدد. للمزيد من المعلومات، راجع علاقات النوع في عمليات استعلام (Visual Basic) وعلاقات النوع في LINQ عمليات استعلام (#C).

مثال

يظهر المثال التالي استعلام بسيط عبر ArrayList. لاحظ أن هذا المثال يستخدم مُهيآت كائن عندما تقوم التعليمات البرمجية تستدعي الأسلوب Add، ولكن هذا غير متطلب.

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
*/

راجع أيضًا:

المبادئ

LINQ إلى الكائنات