From 6d4337fc71ee6e14497318294951b423b896aee7 Mon Sep 17 00:00:00 2001 From: Benjamin Eberlei Date: Sat, 15 Oct 2011 16:14:36 +0200 Subject: [PATCH] More details on partial objects --- en/reference/partial-objects.rst | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/en/reference/partial-objects.rst b/en/reference/partial-objects.rst index 5ce07e5ef..396eecce3 100644 --- a/en/reference/partial-objects.rst +++ b/en/reference/partial-objects.rst @@ -15,6 +15,14 @@ of Doctrine2 to this problem is. ``Query#getScalarResult()``, ``Query#getSingleScalarResult()``, etc. +.. warning:: + + Use of partial objects is tricky. Fields that are not retrieved + from the database will not be updated by the UnitOfWork even if they + get changed in your objects. You can only promote a partial object + to a fully-loaded object by calling ``EntityManager#refresh()`` + or a DQL query with the refresh flag. + What is the problem? -------------------- @@ -60,6 +68,18 @@ keyword as follows: createQuery("select partial u.{id,name} from MyApp\Domain\User u"); +You can also get a partial reference instead of a proxy reference by +calling: + +.. code-block:: php + + getPartialReference('MyApp\Domain\User', 1); + +Partial references are objects with only the identifiers set as they +are passed to the second argument of the ``getPartialReference()`` method. +All other fields are null. + When should I force partial objects? ------------------------------------