DataLoadOptions.LoadWith Método

Definição

Sobrecargas

LoadWith(LambdaExpression)

Recupera dados especificados relacionados ao destino principal usando uma expressão lambda.Retrieves specified data related to the main target by using a lambda expression.

LoadWith<T>(Expression<Func<T,Object>>)

Especifica quais objetos abaixo recuperar quando uma consulta é enviada para um objeto do tipo T.Specifies which sub-objects to retrieve when a query is submitted for an object of type T.

LoadWith(LambdaExpression)

Recupera dados especificados relacionados ao destino principal usando uma expressão lambda.Retrieves specified data related to the main target by using a lambda expression.

public:
 void LoadWith(System::Linq::Expressions::LambdaExpression ^ expression);
public void LoadWith (System.Linq.Expressions.LambdaExpression expression);
member this.LoadWith : System.Linq.Expressions.LambdaExpression -> unit
Public Sub LoadWith (expression As LambdaExpression)

Parâmetros

expression
LambdaExpression

Uma expressão lambda que identifica o material relacionado.A lambda expression that identifies the related material.

Exemplos

Northwnd db = new Northwnd(@"c:\northwnd.mdf");
DataLoadOptions dlo = new DataLoadOptions();
dlo.LoadWith<Customer>(c => c.Orders);
db.LoadOptions = dlo;

var londonCustomers =
    from cust in db.Customers
    where cust.City == "London"
    select cust;

foreach (var custObj in londonCustomers)
{
    Console.WriteLine(custObj.CustomerID);
}
Dim db As New Northwnd("c:\northwnd.mdf")

Dim dlo As DataLoadOptions = New DataLoadOptions()
dlo.LoadWith(Of Customer)(Function(c As Customer) c.Orders)
db.LoadOptions = dlo

Dim londonCustomers = _
    From cust In db.Customers _
    Where cust.City = "London" _
    Select cust

For Each custObj In londonCustomers
    Console.WriteLine(custObj.CustomerID)
Next

Comentários

No exemplo a seguir, qualquer Orders para qualquer Customers que está localizado em Londres é recuperado quando a consulta é executada.In the following example, all the Orders for all the Customers who are located in London are retrieved when the query is executed. Como resultado, o acesso são a propriedade de Orders em um objeto de Customer não dispara uma nova consulta de base de dados.As a result, successive access to the Orders property on a Customer object does not trigger a new database query.

Aplica-se a

LoadWith<T>(Expression<Func<T,Object>>)

Especifica quais objetos abaixo recuperar quando uma consulta é enviada para um objeto do tipo T.Specifies which sub-objects to retrieve when a query is submitted for an object of type T.

public:
generic <typename T>
 void LoadWith(System::Linq::Expressions::Expression<Func<T, System::Object ^> ^> ^ expression);
public void LoadWith<T> (System.Linq.Expressions.Expression<Func<T,object>> expression);
member this.LoadWith : System.Linq.Expressions.Expression<Func<'T, obj>> -> unit
Public Sub LoadWith(Of T) (expression As Expression(Of Func(Of T, Object)))

Parâmetros de tipo

T

O tipo que é consultado.Type that is queried against.

Se esse tipo não estiver mapeado, uma exceção será gerada.If this type is unmapped, an exception is thrown.

Parâmetros

expression
Expression<Func<T,Object>>

Identifica o campo ou propriedade a ser recuperada.Identifies the field or property to be retrieved.

Se a expressão não identificar um campo ou propriedade que representa uma relação um-para-um ou um-para-muitos, uma exceção será gerada.If the expression does not identify a field or property that represents a one-to-one or one-to-many relationship, an exception is thrown.

Exemplos

No exemplo a seguir, qualquer Orders para qualquer Customers que está localizado em Londres é recuperado quando a consulta é executada.In the following example, all the Orders for all the Customers who are located in London are retrieved when the query is executed. Como resultado, o acesso são a propriedade de Orders em um objeto de Customer não dispara uma nova consulta de base de dados.As a result, successive access to the Orders property on a Customer object does not trigger a new database query.

Northwnd db = new Northwnd(@"c:\northwnd.mdf");
DataLoadOptions dlo = new DataLoadOptions();
dlo.LoadWith<Customer>(c => c.Orders);
db.LoadOptions = dlo;

var londonCustomers =
    from cust in db.Customers
    where cust.City == "London"
    select cust;

foreach (var custObj in londonCustomers)
{
    Console.WriteLine(custObj.CustomerID);
}
Dim db As New Northwnd("c:\northwnd.mdf")

Dim dlo As DataLoadOptions = New DataLoadOptions()
dlo.LoadWith(Of Customer)(Function(c As Customer) c.Orders)
db.LoadOptions = dlo

Dim londonCustomers = _
    From cust In db.Customers _
    Where cust.City = "London" _
    Select cust

For Each custObj In londonCustomers
    Console.WriteLine(custObj.CustomerID)
Next

Comentários

Você não pode especificar o carregamento de dois níveis de relações (por exemplo, Orders.OrderDetails ).You cannot specify the loading of two levels of relationships (for example, Orders.OrderDetails). Nesses cenários, você deve especificar dois LoadWith métodos separados.In these scenarios you must specify two separate LoadWith methods.

Para evitar o ciclo, consulte a seção comentários em DataLoadOptions .To avoid cycling, see Remarks section in DataLoadOptions.

Aplica-se a