Queryable.Any Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Determina si existe algún elemento de una secuencia de IQueryable<T> o satisface una condición.
Sobrecargas
Any<TSource>(IQueryable<TSource>) |
Determina si una secuencia contiene elementos. |
Any<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) |
Determina si algún elemento de una secuencia cumple una condición. |
Any<TSource>(IQueryable<TSource>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
Determina si una secuencia contiene elementos.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static bool Any(System::Linq::IQueryable<TSource> ^ source);
public static bool Any<TSource> (this System.Linq.IQueryable<TSource> source);
static member Any : System.Linq.IQueryable<'Source> -> bool
<Extension()>
Public Function Any(Of TSource) (source As IQueryable(Of TSource)) As Boolean
Parámetros de tipo
- TSource
Tipo de los elementos de source
.
Parámetros
- source
- IQueryable<TSource>
Secuencia que se va a comprobar si está vacía.
Devoluciones
true
si la secuencia de origen contiene elementos; de lo contrario, false
.
Excepciones
source
es null
.
Ejemplos
En el ejemplo de código siguiente se muestra cómo usar Any<TSource>(IQueryable<TSource>) para determinar si una secuencia contiene elementos.
List<int> numbers = new List<int> { 1, 2 };
// Determine if the list contains any elements.
bool hasElements = numbers.AsQueryable().Any();
Console.WriteLine("The list {0} empty.",
hasElements ? "is not" : "is");
// This code produces the following output:
//
// The list is not empty.
Dim numbers As New List(Of Integer)(New Integer() {1, 2})
' Determine if the list contains any elements.
Dim hasElements As Boolean = numbers.AsQueryable().Any()
MsgBox(String.Format("The list {0} empty.", _
IIf(hasElements, "is not", "is")))
' This code produces the following output:
'
' The list is not empty.
El valor booleano que devuelve el método Any<TSource>(IQueryable<TSource>) se usa normalmente en el predicado de una cláusula where
(Where
cláusula en Visual Basic) o una llamada directa al método Where<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>). En el ejemplo siguiente se muestra este uso del método Any
.
class Pet
{
public string Name { get; set; }
public int Age { get; set; }
}
class Person
{
public string LastName { get; set; }
public Pet[] Pets { get; set; }
}
public static void AnyEx2()
{
List<Person> people = new List<Person>
{ new Person { LastName = "Haas",
Pets = new Pet[] { new Pet { Name="Barley", Age=10 },
new Pet { Name="Boots", Age=14 },
new Pet { Name="Whiskers", Age=6 }}},
new Person { LastName = "Fakhouri",
Pets = new Pet[] { new Pet { Name = "Snowball", Age = 1}}},
new Person { LastName = "Antebi",
Pets = new Pet[] { }},
new Person { LastName = "Philips",
Pets = new Pet[] { new Pet { Name = "Sweetie", Age = 2},
new Pet { Name = "Rover", Age = 13}} }
};
// Determine which people have a non-empty Pet array.
IEnumerable<string> names = from person in people
where person.Pets.AsQueryable().Any()
select person.LastName;
foreach (string name in names)
Console.WriteLine(name);
/* This code produces the following output:
Haas
Fakhouri
Philips
*/
}
Structure Pet
Public Name As String
Public Age As Integer
End Structure
Structure Person
Public LastName As String
Public Pets() As Pet
End Structure
Sub AnyEx2()
Dim people As New List(Of Person)(New Person() _
{New Person With {.LastName = "Haas", _
.Pets = New Pet() {New Pet With {.Name = "Barley", .Age = 10}, _
New Pet With {.Name = "Boots", .Age = 14}, _
New Pet With {.Name = "Whiskers", .Age = 6}}}, _
New Person With {.LastName = "Fakhouri", _
.Pets = New Pet() {New Pet With {.Name = "Snowball", .Age = 1}}}, _
New Person With {.LastName = "Antebi", _
.Pets = New Pet() {}}, _
New Person With {.LastName = "Philips", _
.Pets = New Pet() {New Pet With {.Name = "Sweetie", .Age = 2}, _
New Pet With {.Name = "Rover", .Age = 13}}}})
' Determine which people have a non-empty Pet array.
Dim names = From person In people _
Where person.Pets.AsQueryable().Any() _
Select person.LastName
For Each name As String In names
Console.WriteLine(name)
Next
' This code produces the following output:
'
' Haas
' Fakhouri
' Philips
End Sub
Comentarios
El método Any<TSource>(IQueryable<TSource>) genera un MethodCallExpression que representa la llamada a Any<TSource>(IQueryable<TSource>) como un método genérico construido. A continuación, pasa el MethodCallExpression al método Execute<TResult>(Expression) del IQueryProvider representado por la propiedad Provider del parámetro source
.
El comportamiento de la consulta que se produce como resultado de ejecutar un árbol de expresión que representa la llamada a Any<TSource>(IQueryable<TSource>) depende de la implementación del tipo del parámetro source
. El comportamiento esperado es que determina si source
contiene elementos.
Se aplica a
Any<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
Determina si algún elemento de una secuencia cumple una condición.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static bool Any(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, bool> ^> ^ predicate);
public static bool Any<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,bool>> predicate);
static member Any : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, bool>> -> bool
<Extension()>
Public Function Any(Of TSource) (source As IQueryable(Of TSource), predicate As Expression(Of Func(Of TSource, Boolean))) As Boolean
Parámetros de tipo
- TSource
Tipo de los elementos de source
.
Parámetros
- source
- IQueryable<TSource>
Secuencia cuyos elementos se van a probar para una condición.
- predicate
- Expression<Func<TSource,Boolean>>
Función para probar cada elemento de una condición.
Devoluciones
true
si algún elemento de la secuencia de origen pasa la prueba en el predicado especificado; de lo contrario, false
.
Excepciones
source
o predicate
es null
.
Ejemplos
En el ejemplo de código siguiente se muestra cómo usar Any<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) para determinar si algún elemento de una secuencia cumple una condición.
class Pet
{
public string Name { get; set; }
public int Age { get; set; }
public bool Vaccinated { get; set; }
}
public static void AnyEx3()
{
// Create an array of Pet objects.
Pet[] pets =
{ new Pet { Name="Barley", Age=8, Vaccinated=true },
new Pet { Name="Boots", Age=4, Vaccinated=false },
new Pet { Name="Whiskers", Age=1, Vaccinated=false } };
// Determine whether any pets over age 1 are also unvaccinated.
bool unvaccinated =
pets.AsQueryable().Any(p => p.Age > 1 && p.Vaccinated == false);
Console.WriteLine(
"There {0} unvaccinated animals over age one.",
unvaccinated ? "are" : "are not any");
}
// This code produces the following output:
//
// There are unvaccinated animals over age one.
Structure Pet
Dim Name As String
Dim Age As Integer
Dim Vaccinated As Boolean
End Structure
Shared Sub AnyEx3()
' Create an array of Pet objects.
Dim pets() As Pet = _
{New Pet With {.Name = "Barley", .Age = 8, .Vaccinated = True}, _
New Pet With {.Name = "Boots", .Age = 4, .Vaccinated = False}, _
New Pet With {.Name = "Whiskers", .Age = 1, .Vaccinated = False}}
' Determine whether any pets over age 1 are also unvaccinated.
Dim unvaccinated As Boolean = _
pets.AsQueryable().Any(Function(p) p.Age > 1 And p.Vaccinated = False)
MsgBox(String.Format( _
"There {0} unvaccinated animals over age one.", _
IIf(unvaccinated, "are", "are not any") _
))
End Sub
' This code produces the following output:
'
' There are unvaccinated animals over age one.
Comentarios
Este método tiene al menos un parámetro de tipo Expression<TDelegate> cuyo argumento de tipo es uno de los tipos de Func<T,TResult>. Para estos parámetros, puede pasar una expresión lambda y se compilará en un Expression<TDelegate>.
El método Any<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) genera un MethodCallExpression que representa la llamada a Any<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) como un método genérico construido. A continuación, pasa el MethodCallExpression al método Execute<TResult>(Expression) del IQueryProvider representado por la propiedad Provider del parámetro source
.
El comportamiento de la consulta que se produce como resultado de ejecutar un árbol de expresión que representa la llamada a Any<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) depende de la implementación del tipo del parámetro source
. El comportamiento esperado es que determina si alguno de los elementos de source
cumple la condición especificada por predicate
.