방법: 관련 데이터가 검색되는 양 제어(LINQ to SQL)
업데이트: November 2007
LoadWith 메서드를 사용하여 동시에 검색되어야 하는 주 대상과 관련된 데이터를 지정합니다. 예를 들어 고객 주문에 대한 정보가 필요한 경우 LoadWith를 사용하여 주문 정보와 고객 정보가 검색되었는지 확인합니다. 이 접근 방법은 두 가지 정보에 대한 데이터베이스에서 원트립만의 결과입니다.
참고: |
---|
고객을 대상으로 할 경우 주문을 검색하는 것과 같이 외적을 하나의 큰 프로젝션처럼 검색하여 쿼리의 주 대상과 관련된 데이터를 검색할 수 있습니다. 그러나 이러한 방법에는 종종 단점이 있습니다. 예를 들어 결과는 엔터티가 아니라 프로젝션이기에 LINQ to SQL에서 변경되고 유지될 수 있습니다. 원하지 않는 많은 데이터가 검색될 수 있습니다. |
예제
다음 예제에서 쿼리를 실행하면 런던에 살고 있는 모든 Customers에 대한 모든 Orders가 검색됩니다. 따라서 Customer 개체의 Orders 속성으로의 연속적 액세스는 새로운 데이터베이스 쿼리를 트리거하지 않습니다.
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
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);
}