다음을 통해 공유


방법: 관련 데이터 검색의 양 제어

LoadWith 메서드를 사용하여 동시에 검색되어야 하는 주 대상과 관련된 데이터를 지정합니다. 예를 들어 고객 주문에 대한 정보가 필요한 경우 LoadWith를 사용하여 주문 정보와 고객 정보가 검색되었는지 확인합니다. 이 접근 방법은 두 가지 정보에 대한 데이터베이스에서 원트립만의 결과입니다.

참고 항목

고객을 대상으로 할 경우 주문을 검색하는 것과 같이 외적을 하나의 큰 프로젝션처럼 검색하여 쿼리의 주 대상과 관련된 데이터를 검색할 수 있습니다. 그러나 이러한 방법에는 종종 단점이 있습니다. 예를 들어 결과는 엔터티가 아니라 프로젝션이므로 LINQ to SQL에서 변경되고 유지될 수 있습니다. 원하지 않는 많은 데이터가 검색될 수 있습니다.

예시

다음 예제에서는 런던에 있는 모든 Customers에 대한 모든 Orders가 쿼리가 실행될 때 검색됩니다. 따라서 Customer 개체의 Orders 속성에 대한 연속 액세스는 새 데이터베이스 쿼리를 트리거하지 않습니다.

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

참고 항목