Zum Ende der Metadaten springen
Zum Anfang der Metadaten

Sie zeigen eine alte Version dieser Seite an. Zeigen Sie die aktuelle Version an.

Unterschiede anzeigen Seitenhistorie anzeigen

« Vorherige Version anzeigen Version 6 Nächste Version anzeigen »

Das Kopieren von Datensätzen ist in Doctrine\Manager\CopyManager geregelt. Es stehen unterschiedliche Methoden zur Verfügung, um das Kopieren zu ermöglichen (siehe nachfolgende Überschicht).

Hinweis

Alle Methoden erlauben das Kopieren vieler Datensätze in einem Aufruf.


MethodeBeschreibung
rootEs wird der Stammdatensatz kopiert. Sprachen werden nicht kopiert.
defaultEs wird der Stammdatensatz mit Sprachen kopiert.
withRelationWie default, der Stammdatensatz wird aber zusätzlich zu Eltern- und Kindern verknüpft, zu denen der Ursprungsdatensatz auch verknüpft ist. 
recursiveWie default, jedoch werden hier alle Kinder und Kindeskinder ebenfalls kopiert. Es wird die vollständige Rekursionskette kopiert. 

Aufruf

use Brandbox\Framework\Brandbox\Doctrine;  

$ids = [1,2,3,4,5];
$entities = [$repository => $ids]  

$logger = $this
  ->staticController(Doctrine\Manager\CopyManager::class)
  ->root($entities)
;
 
$logger = $this
  ->staticController(Doctrine\Manager\CopyManager::class)
  ->default($entities)
;

$logger = $this
  ->staticController(Doctrine\Manager\CopyManager::class)
  ->withRelation($entities)
;

$logger = $this
  ->staticController(Doctrine\Manager\CopyManager::class)
  ->recursive($entities)
;

Verwendung des Loggers

Die Kopiervorgänge werden intern geloggt. Nach dem Kopiervorgang kann auf die Nachrichten sowie die kopierten Ids zugegriffen werden. 

use Brandbox\Framework\Brandbox\Doctrine; 

$copyManager = $this->staticController(Doctrine\Manager\CopyManager::class);

$logger = $copyManager->root($entities);
 
$copiedId = $copyManager->getCopiedId($logger, $repository, $sourceId);
$messages = $logger->all();

Eventübersicht

KlassennameBeschreibung
OnExecuteManagerCopyWird von allen Methoden in Doctrine\Manager\CopyManager::class ausgelöst
OnExecuteManagerTruncateWird von Doctrine\Manager\DeleteManager::truncate() ausgelöst
  • Keine Stichwörter