Merge pull request #10827 from creative-commoners/pulls/5/doc-eagerload

DOC Update eagerLoad() docblock
This commit is contained in:
Guy Sartorelli 2023-06-21 16:44:16 +12:00 committed by GitHub
commit 6bf32c9e20
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1209,7 +1209,19 @@ class DataList extends ViewableData implements SS_List, Filterable, Sortable, Li
} }
/** /**
* $myDataList->eagerLoad('Some.Nested.Relation', 'Another.Relation') * Eager load relations for DataObjects in this DataList including nested relations
*
* Eager loading alleviates the N + 1 problem by querying the nested relationship tables before they are
* needed using a single large `WHERE ID in ($ids)` SQL query instead of many `WHERE RelationID = $id` queries.
*
* You can speicify nested relations by using dot notation, and you can also pass in multiple relations.
* When speicifying nested relations there is a maximum of 3 levels of relations allowed i.e. 2 dots
*
* Example:
* $myDataList->eagerLoad('MyRelation.NestedRelation.EvenMoreNestedRelation', 'DifferentRelation')
*
* IMPORTANT: Calling eagerLoad() will cause any relations on DataObjects to be returned as an ArrayList
* instead of a subclass of DataList such as HasManyList i.e. MyDataObject->MyHasManyRelation() returns an ArrayList
*/ */
public function eagerLoad(...$relations): static public function eagerLoad(...$relations): static
{ {