Entities in the Session ======================= There are several use-cases to save entities in the session, for example: 1. User object 2. Multi-step forms To achieve this with Doctrine you have to pay attention to some details to get this working. Merging entity into an EntityManager ------------------------------------ In Doctrine an entity objects has to be "managed" by an EntityManager to be updateable. Entities saved into the session are not managed in the next request anymore. This means that you have to register these entities with an EntityManager again if you want to change them or use them as part of references between other entities. You can achieve this by calling ``EntityManager#merge()``. For a representative User object the code to get turn an instance from the session into a managed Doctrine object looks like this: .. code-block:: php <?php require_once 'bootstrap.php'; $em = GetEntityManager(); // creates an EntityManager session_start(); if (isset($_SESSION['user']) && $_SESSION['user'] instanceof User) { $user = $_SESSION['user']; $user = $em->merge($user); } .. note:: A frequent mistake is not to get the merged user object from the return value of ``EntityManager#merge()``. The entity object passed to merge is not necessarily the same object that is returned from the method. Serializing entity into the session ----------------------------------- Entities that are serialized into the session normally contain references to other entities as well. Think of the user entity has a reference to their articles, groups, photos or many other different entities. If you serialize this object into the session then you don't want to serialize the related entities as well. This is why you should call ``EntityManager#detach()`` on this object or implement the __sleep() magic method on your entity. .. code-block:: php <?php require_once 'bootstrap.php'; $em = GetEntityManager(); // creates an EntityManager $user = $em->find("User", 1); $em->detach($user); $_SESSION['user'] = $user; .. note:: When you called detach on your objects they get "unmanaged" with that entity manager. This means you cannot use them as part of write operations during ``EntityManager#flush()`` anymore in this request.
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
advanced-field-value-conversion-using-custom-mapping-types.rst | File | 7.07 KB | 0644 |
|
aggregate-fields.rst | File | 11.41 KB | 0644 |
|
custom-mapping-types.rst | File | 3.04 KB | 0644 |
|
decorator-pattern.rst | File | 6.65 KB | 0644 |
|
dql-custom-walkers.rst | File | 7.75 KB | 0644 |
|
dql-user-defined-functions.rst | File | 9.39 KB | 0644 |
|
entities-in-session.rst | File | 2.29 KB | 0644 |
|
implementing-arrayaccess-for-domain-objects.rst | File | 3.06 KB | 0644 |
|
implementing-the-notify-changetracking-policy.rst | File | 2.36 KB | 0644 |
|
implementing-wakeup-or-clone.rst | File | 2.23 KB | 0644 |
|
integrating-with-codeigniter.rst | File | 4.18 KB | 0644 |
|
mysql-enums.rst | File | 5.79 KB | 0644 |
|
resolve-target-entity-listener.rst | File | 4.4 KB | 0644 |
|
sql-table-prefixes.rst | File | 2.78 KB | 0644 |
|
strategy-cookbook-introduction.rst | File | 8.54 KB | 0644 |
|
validation-of-entities.rst | File | 4.31 KB | 0644 |
|
working-with-datetime.rst | File | 6.57 KB | 0644 |
|