Doctrine 2 - ORM
  1. Doctrine 2 - ORM
  2. DDC-2839

[GH-869] Detach objects in original object data

    Details

    • Type: Bug Bug
    • Status: Open
    • Priority: Major Major
    • Resolution: Unresolved
    • Affects Version/s: None
    • Fix Version/s: None
    • Component/s: None
    • Security Level: All
    • Labels:
      None

      Description

      This issue is created automatically through a Github pull request on behalf of tomphp:

      Url: https://github.com/doctrine/doctrine2/pull/869

      Message:

      The PR makes Doctrine ORM update the database when you execute something like this:

      ```php
      // MyEntity.php

      /**

      • @Entity
        */
        class MyEntity
        {
        // ...

      /**

      • @Column(type="datetime")
        */
        private $created;

      // ...

      public function setCreated(\DateTime $created)

      { $this->created = $created; }

      public function getCreated()

      { return $this->created; }

      // ...
      }
      ```

      ```php
      // Current problem

      $entity = $entityManager->find('MyEntity', 1);

      $entity->getCreated()->setDate('2001-01-01');

      $entityManager->persist($entity);

      $entityManager->flush();

      // At this point no changes have been made to the database!
      ```

      The reason this doesn't work currently is because the array of original data stored in the UnitOfWork contains the actual DateTime object which is in the entity. When you update the object in the entity the original data is updated also so the entity are the original value are still equal and therefore the object is not seen as changed.

      I have chosen to clone all objects rather than just DateTime object include more types are included in the future.

        Activity

        Doctrine Bot created issue -
        Hide
        Doctrine Bot added a comment -

        A related Github Pull-Request [GH-869] was closed:
        https://github.com/doctrine/doctrine2/pull/869

        Show
        Doctrine Bot added a comment - A related Github Pull-Request [GH-869] was closed: https://github.com/doctrine/doctrine2/pull/869

        This list may be incomplete, as errors occurred whilst retrieving source from linked applications:

        • Request to http://www.doctrine-project.org/fisheye/ failed: Error in remote call to 'FishEye 0 (http://www.doctrine-project.org/fisheye/)' (http://www.doctrine-project.org/fisheye) [AbstractRestCommand{path='/rest-service-fe/search-v1/crossRepositoryQuery', params={query=DDC-2839, expand=changesets[0:20].revisions[0:29],reviews}, methodType=GET}] : Received status code 503 (Service Temporarily Unavailable)

          People

          • Assignee:
            Benjamin Eberlei
            Reporter:
            Doctrine Bot
          • Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

            Dates

            • Created:
              Updated: