program tip

지연 로딩 vs Eager 로딩

radiobox 2020. 12. 1. 07:51
반응형

지연 로딩 vs Eager 로딩


Entity Framework의 지연로드는 관련 엔터티를로드하고 액세스 할 때 발생하는 기본 현상입니다. 그러나 eager loading은 이러한 모든 관계에 힘을 가하는 관행을 말합니다. 나는 어떤 상황에서 eager loading이 lazy loading보다 더 유익 할 수 있는지에 대한 질문을 보았습니다. 이것에 대해 물어 보면, 지연 로딩이 더 자원 친화적 인 것이 분명하고 ToList(), 우리가 방법 을 사용하더라도 지연 로딩 동작을 여전히 이용할 수 있기 때문입니다. 그러나 지연로드가 실제 데이터베이스에 대한 요청 수를 증가시킬 수 있다고 생각했고, 이것이 개발자가Inlcude모든 관계를 강제로로드하는 방법입니다. 예를 들어 MVC 5에서 Visual Studio 자동 스캐 폴딩을 사용할 때 컨트롤러에서 자동으로 생성되는 Index 메서드는 항상 Eager Loading을 사용하며,이 경우 Microsoft가 기본적으로 Eager Loading을 사용하는 이유에 대한 질문이 항상있었습니다.

누군가가 지연 로딩보다 eager loading이 어떤 상황에서 더 유익한 지, 왜 우리가 Lazy Loading과 같은 리소스 친화적 인 것이 있는데 왜 그것을 사용하는지 설명 해주면 감사하겠습니다.


이렇게 관계를 분류하면 좋을 것 같아요

즉시 로딩을 사용하는 경우

  1. 일대 다 관계의 "일면"에서 당신은 확실히 주요 엔티티와 함께 ​​모든 곳에서 사용됩니다. 기사의 사용자 속성과 같습니다. 제품의 범주 속성입니다.
  2. 일반적으로 관계가 너무 많지 않고 eager loading이 서버에서 추가 쿼리를 줄이는 데 좋은 습관이 될 때.

지연 로딩을 사용하는 경우

  1. 일대 다 관계의 거의 모든 "수집 측면"에 있습니다. 사용자 기사 또는 카테고리 제품
  2. 즉시 재산이 필요하지 않다는 것을 정확히 알고 있습니다.

참고 : Transcendent가 말한 것처럼 지연 로딩에 폐기 문제가있을 수 있습니다.


Eager Loading : Eager Loading은 필요한 모든 엔티티를 한 번에로드하는 데 도움이됩니다. 즉 관련 개체 (하위 개체)는 상위 개체와 함께 자동으로로드됩니다.

사용시기 :

  1. 관계가 너무 많지 않을 때 Eager Loading을 사용합니다. 따라서 Eager Loading은 서버에서 추가 쿼리를 줄이는 좋은 방법입니다.
  2. 모든 곳에서 주요 엔터티와 함께 ​​관련 엔터티를 사용할 것이 확실한 경우 Eager Loading을 사용합니다.

지연로드 : 지연로드의 경우 관련 개체 (하위 개체)는 요청 될 때까지 부모 개체와 함께 자동으로로드되지 않습니다. 기본적으로 LINQ는 지연로드를 지원합니다.

사용시기 :

  1. 일대 다 컬렉션을 사용하는 경우 지연로드를 사용합니다.
  2. 관련 엔터티를 즉시 사용하지 않는 것이 확실한 경우 지연로드를 사용하십시오.

참고 : Entity Framework는 즉시로드, 지연로드 및 명시 적로드의 세 가지 관련 데이터로드 방법을 지원합니다.


지연로드는 여러 SQL 호출을 생성하는 반면 Eager로드는 하나의 "더 무거운"호출 (조인 / 서브 쿼리 포함)으로 데이터를로드 할 수 있습니다.

예를 들어, 웹 서버와 SQL 서버간에 높은 핑이있는 경우 지연로드로 관련 항목을 1x1로로드하는 대신 Eager로드를 사용합니다.


아래 상황을 고려하십시오

public class Person{
    public String Name{get; set;}
    public String Email {get; set;}
    public virtual Employer employer {get; set;}
}

public List<EF.Person> GetPerson(){
    using(EF.DbEntities db = new EF.DbEntities()){
       return db.Person.ToList();
    }
}

이제이 메서드가 호출 된 후에는 Employer더 이상 엔터티를 지연로드 할 수 없습니다 . 왜? db객체가 폐기 되었기 때문 입니다. 그래서 Person.Include(x=> x.employer)그것을 강제로로드해야합니다.


Eager Loading 한 번에 여러 엔터티를 가져오고 싶은 경우 (예 : 동일한 페이지에 사용자 및 사용자 세부 정보를 표시해야하는 경우) 즉시로드를 사용해야합니다. 빠른로드는 데이터베이스에서 단일 히트를 만들고 관련 엔티티를로드합니다.

지연 로딩 페이지에서만 사용자를 표시해야하고 사용자를 클릭하여 사용자 세부 사항을 표시해야하는 경우 지연 로딩을 사용해야합니다. 지연로드는 관련 항목을 바인딩 / 반복 할 때 관련 항목을로드하기 위해 여러 히트를 만듭니다.


// Using LINQ and just referencing p.Employer will lazy load
// I am not at a computer but I know I have lazy loaded in one
// query with a single query call like below.
List<Person> persons = new List<Person>();
using(MyDbContext dbContext = new MyDbContext())
{
    persons = (
        from p in dbcontext.Persons
        select new Person{
            Name = p.Name,
            Email = p.Email,
            Employer = p.Employer
        }).ToList();
}

가능하면 즉시로드를 사용하는 것이 좋습니다. 애플리케이션 성능을 최적화하기 때문입니다.

전의-:

Eager loading

var customers= _context.customers.Include(c=> c.membershipType).Tolist();

lazy loading

모델에서 고객은 정의해야합니다

Public virtual string membershipType {get; set;}

따라서 지연로드를 쿼리 할 때 모든 참조 객체를로드하는 것이 훨씬 느리지 만 열망로드 쿼리는 관련 객체 만 선택합니다.

참고 URL : https://stackoverflow.com/questions/31366236/lazy-loading-vs-eager-loading

반응형