Queryable.Concat<TSource> Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
İki diziyi birleştirir.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TSource> ^ Concat(System::Linq::IQueryable<TSource> ^ source1, System::Collections::Generic::IEnumerable<TSource> ^ source2);
public static System.Linq.IQueryable<TSource> Concat<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2);
static member Concat : System.Linq.IQueryable<'Source> * seq<'Source> -> System.Linq.IQueryable<'Source>
<Extension()>
Public Function Concat(Of TSource) (source1 As IQueryable(Of TSource), source2 As IEnumerable(Of TSource)) As IQueryable(Of TSource)
Tür Parametreleri
- TSource
Giriş dizilerinin öğelerinin türü.
Parametreler
- source1
- IQueryable<TSource>
Birleştirilmeye ilk sıra.
- source2
- IEnumerable<TSource>
İlk sıraya birleştirilme sırası.
Döndürülenler
IQueryable<T> İki giriş dizisinin birleştirilmiş öğelerini içeren bir.
Özel durumlar
source1
veya source2
şeklindedir null
.
Örnekler
Aşağıdaki kod örneği, iki diziyi birleştirmek için nasıl kullanılacağını Concat<TSource>(IQueryable<TSource>, IEnumerable<TSource>) gösterir.
class Pet
{
public string Name { get; set; }
public int Age { get; set; }
}
// This method creates and returns an array of Pet objects.
static Pet[] GetCats()
{
Pet[] cats = { new Pet { Name="Barley", Age=8 },
new Pet { Name="Boots", Age=4 },
new Pet { Name="Whiskers", Age=1 } };
return cats;
}
// This method creates and returns an array of Pet objects.
static Pet[] GetDogs()
{
Pet[] dogs = { new Pet { Name="Bounder", Age=3 },
new Pet { Name="Snoopy", Age=14 },
new Pet { Name="Fido", Age=9 } };
return dogs;
}
public static void ConcatEx1()
{
Pet[] cats = GetCats();
Pet[] dogs = GetDogs();
// Concatenate a collection of cat names to a
// collection of dog names by using Concat().
IEnumerable<string> query =
cats.AsQueryable()
.Select(cat => cat.Name)
.Concat(dogs.Select(dog => dog.Name));
foreach (string name in query)
Console.WriteLine(name);
}
// This code produces the following output:
//
// Barley
// Boots
// Whiskers
// Bounder
// Snoopy
// Fido
' This method creates and returns an array of Pet objects.
Shared Function GetCats() As Pet()
Dim cats() As Pet = _
{New Pet With {.Name = "Barley", .Age = 8}, _
New Pet With {.Name = "Boots", .Age = 4}, _
New Pet With {.Name = "Whiskers", .Age = 1}}
Return cats
End Function
' This method creates and returns an array of Pet objects.
Shared Function GetDogs() As Pet()
Dim dogs() As Pet = _
{New Pet With {.Name = "Bounder", .Age = 3}, _
New Pet With {.Name = "Snoopy", .Age = 14}, _
New Pet With {.Name = "Fido", .Age = 9}}
Return dogs
End Function
Shared Sub ConcatEx1()
Dim cats() As Pet = GetCats()
Dim dogs() As Pet = GetDogs()
' Concatenate a collection of cat names to a
' collection of dog names by using Concat().
Dim query As IEnumerable(Of String) = _
cats.AsQueryable() _
.Select(Function(cat) cat.Name) _
.Concat(dogs.Select(Function(dog) dog.Name))
For Each name As String In query
MsgBox(name)
Next
End Sub
Structure Pet
Dim Name As String
Dim Age As Integer
End Structure
' This code produces the following output:
'
' Barley
' Boots
' Whiskers
' Bounder
' Snoopy
' Fido
Açıklamalar
yöntemi, Concat<TSource>(IQueryable<TSource>, IEnumerable<TSource>) kendisini oluşturulan genel bir MethodCallExpression yöntem olarak çağıran Concat<TSource>(IQueryable<TSource>, IEnumerable<TSource>) bir oluşturur. Ardından parametresinin MethodCallExpressionCreateQuery<TElement>(Expression) özelliği tarafından temsil edilen yöntemine IQueryProviderProvidersource1
iletir.
Çağrıyı Concat<TSource>(IQueryable<TSource>, IEnumerable<TSource>) temsil eden bir ifade ağacının yürütülmesi sonucunda oluşan sorgu davranışı, parametre türünün uygulanmasına source1
bağlıdır. Beklenen davranış, içindeki source2
öğelerinin yeni bir dizi oluşturmak için öğeleriyle source1
birleştirilmiş olmasıdır.