diff --git a/en/index.rst b/en/index.rst index c58b7528c..16800fe21 100644 --- a/en/index.rst +++ b/en/index.rst @@ -25,7 +25,7 @@ of contents `. Getting Started --------------- -* **Tutorial**: +* **Tutorial**: :doc:`Getting Started ` | :doc:`In 10 quick steps ` @@ -59,20 +59,21 @@ Working with Objects :doc:`Assocations ` | :doc:`Events ` -* **Querying Objects**: +* **Query Reference**: :doc:`Doctrine Query Language (DQL) ` | :doc:`QueryBuilder ` | :doc:`Native SQL Queries ` * **UnitOfWork dissected**: :doc:`Doctrine Internals explained ` | - :doc:`Owning and Inverse Side Associations ` + :doc:`Owning and Inverse Side Associations ` * **Tutorials**: :doc:`Indexed associations ` | :doc:`Extra Lazy Assocations ` | :doc:`Composite Primary Keys ` | - :doc:`Ordered associations ` + :doc:`Ordered associations ` | + :doc:`Pagination ` Advanced Topics --------------- diff --git a/en/tutorials/pagination.rst b/en/tutorials/pagination.rst new file mode 100644 index 000000000..ef04a8d89 --- /dev/null +++ b/en/tutorials/pagination.rst @@ -0,0 +1,40 @@ +Pagination +========== + +Starting with version 2.2 Doctrine ships with a Paginator for DQL queries. It +has a very simple API and implements the SPL interfaces ``Countable`` and +``IteratorAggregate``. + +Paginating Doctrine queries is not as simple as you might think in the +beginning. If you have complex fetch-join scenarios with one-to-many or +many-to-many associations using the "default" LIMIT functionality of database +vendors is not sufficient to get the correct results. + +By default the pagination extension does the following steps to compute the +correct result: + +1. Perform a Count query using `DISTINCT` keyword. +2. Perform a Limit Subquery with `DISTINCT` to find all ids of the entity in from on the current page. +3. Perform a WHERE IN query to get all results for the current page. + +This behavior is only necessary if you actually fetch join a to-many +collection. You can disable this behavior by setting the +``$fetchJoinCollection`` flag of. We hope to automate the detection for this in +the future. + +.. code-block:: php + + createQuery($dql) + ->setFirstResult(0) + ->setMaxResults(100); + + $paginator = new Paginator($query, $fetchJoin = true); + + $c = count($paginator); + foreach ($paginator as $post) { + echo $post->getHeadline() . "\n"; + }