@@ -35,11 +35,11 @@ discard block |
||
35 | 35 | protected function configure() |
36 | 36 | { |
37 | 37 | $this->setName($this->name) |
38 | - ->setDescription('Executes (or dumps) the SQL needed to update the database schema to match the current mapping metadata') |
|
39 | - ->addOption('complete', null, InputOption::VALUE_NONE, 'If defined, all assets of the database which are not relevant to the current metadata will be dropped.') |
|
40 | - ->addOption('dump-sql', null, InputOption::VALUE_NONE, 'Dumps the generated SQL statements to the screen (does not execute them).') |
|
41 | - ->addOption('force', 'f', InputOption::VALUE_NONE, 'Causes the generated SQL statements to be physically executed against your database.') |
|
42 | - ->setHelp(<<<'EOT' |
|
38 | + ->setDescription('Executes (or dumps) the SQL needed to update the database schema to match the current mapping metadata') |
|
39 | + ->addOption('complete', null, InputOption::VALUE_NONE, 'If defined, all assets of the database which are not relevant to the current metadata will be dropped.') |
|
40 | + ->addOption('dump-sql', null, InputOption::VALUE_NONE, 'Dumps the generated SQL statements to the screen (does not execute them).') |
|
41 | + ->addOption('force', 'f', InputOption::VALUE_NONE, 'Causes the generated SQL statements to be physically executed against your database.') |
|
42 | + ->setHelp(<<<'EOT' |
|
43 | 43 | The <info>%command.name%</info> command generates the SQL needed to |
44 | 44 | synchronize the database schema with the current mapping metadata of the |
45 | 45 | default entity manager. |
@@ -69,7 +69,7 @@ discard block |
||
69 | 69 | |
70 | 70 | $config->setFilterSchemaAssetsExpression($regexp); |
71 | 71 | EOT |
72 | - ); |
|
72 | + ); |
|
73 | 73 | } |
74 | 74 | |
75 | 75 | /** |
@@ -30,9 +30,9 @@ discard block |
||
30 | 30 | protected function configure() |
31 | 31 | { |
32 | 32 | $this->setName('orm:clear-cache:metadata') |
33 | - ->setDescription('Clear all metadata cache of the various cache drivers') |
|
34 | - ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, cache entries will be flushed instead of deleted/invalidated.') |
|
35 | - ->setHelp(<<<'EOT' |
|
33 | + ->setDescription('Clear all metadata cache of the various cache drivers') |
|
34 | + ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, cache entries will be flushed instead of deleted/invalidated.') |
|
35 | + ->setHelp(<<<'EOT' |
|
36 | 36 | The <info>%command.name%</info> command is meant to clear the metadata cache of associated Entity Manager. |
37 | 37 | It is possible to invalidate all cache entries at once - called delete -, or flushes the cache provider |
38 | 38 | instance completely. |
@@ -49,7 +49,7 @@ discard block |
||
49 | 49 | Finally, be aware that if <info>--flush</info> option is passed, not all cache providers are able to flush entries, |
50 | 50 | because of a limitation of its execution nature. |
51 | 51 | EOT |
52 | - ); |
|
52 | + ); |
|
53 | 53 | } |
54 | 54 | |
55 | 55 | /** |
@@ -57,7 +57,7 @@ discard block |
||
57 | 57 | $em = $this->getHelper('em')->getEntityManager(); |
58 | 58 | $cacheDriver = $em->getConfiguration()->getMetadataCacheImpl(); |
59 | 59 | |
60 | - if (! $cacheDriver) { |
|
60 | + if ( ! $cacheDriver) { |
|
61 | 61 | throw new InvalidArgumentException('No Metadata cache driver is configured on given EntityManager.'); |
62 | 62 | } |
63 | 63 | |
@@ -79,7 +79,7 @@ discard block |
||
79 | 79 | $message = $result ? 'Successfully flushed cache entries.' : $message; |
80 | 80 | } |
81 | 81 | |
82 | - if (! $result) { |
|
82 | + if ( ! $result) { |
|
83 | 83 | $ui->error($message); |
84 | 84 | |
85 | 85 | return 1; |
@@ -27,11 +27,11 @@ discard block |
||
27 | 27 | protected function configure() |
28 | 28 | { |
29 | 29 | $this->setName('orm:clear-cache:region:query') |
30 | - ->setDescription('Clear a second-level cache query region') |
|
31 | - ->addArgument('region-name', InputArgument::OPTIONAL, 'The query region to clear.') |
|
32 | - ->addOption('all', null, InputOption::VALUE_NONE, 'If defined, all query regions will be deleted/invalidated.') |
|
33 | - ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, all cache entries will be flushed.') |
|
34 | - ->setHelp(<<<'EOT' |
|
30 | + ->setDescription('Clear a second-level cache query region') |
|
31 | + ->addArgument('region-name', InputArgument::OPTIONAL, 'The query region to clear.') |
|
32 | + ->addOption('all', null, InputOption::VALUE_NONE, 'If defined, all query regions will be deleted/invalidated.') |
|
33 | + ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, all cache entries will be flushed.') |
|
34 | + ->setHelp(<<<'EOT' |
|
35 | 35 | The <info>%command.name%</info> command is meant to clear a second-level cache query region for an associated Entity Manager. |
36 | 36 | It is possible to delete/invalidate all query region, a specific query region or flushes the cache provider. |
37 | 37 | |
@@ -55,7 +55,7 @@ discard block |
||
55 | 55 | Finally, be aware that if <info>--flush</info> option is passed, |
56 | 56 | not all cache providers are able to flush entries, because of a limitation of its execution nature. |
57 | 57 | EOT |
58 | - ); |
|
58 | + ); |
|
59 | 59 | } |
60 | 60 | |
61 | 61 | /** |
@@ -75,7 +75,7 @@ discard block |
||
75 | 75 | $name = Cache::DEFAULT_QUERY_REGION_NAME; |
76 | 76 | } |
77 | 77 | |
78 | - if (! $cache instanceof Cache) { |
|
78 | + if ( ! $cache instanceof Cache) { |
|
79 | 79 | throw new InvalidArgumentException('No second-level cache is configured on the given EntityManager.'); |
80 | 80 | } |
81 | 81 | |
@@ -83,7 +83,7 @@ discard block |
||
83 | 83 | $queryCache = $cache->getQueryCache($name); |
84 | 84 | $queryRegion = $queryCache->getRegion(); |
85 | 85 | |
86 | - if (! $queryRegion instanceof DefaultRegion) { |
|
86 | + if ( ! $queryRegion instanceof DefaultRegion) { |
|
87 | 87 | throw new InvalidArgumentException(sprintf( |
88 | 88 | 'The option "--flush" expects a "Doctrine\ORM\Cache\Region\DefaultRegion", but got "%s".', |
89 | 89 | is_object($queryRegion) ? get_class($queryRegion) : gettype($queryRegion) |
@@ -30,9 +30,9 @@ discard block |
||
30 | 30 | protected function configure() |
31 | 31 | { |
32 | 32 | $this->setName('orm:clear-cache:query') |
33 | - ->setDescription('Clear all query cache of the various cache drivers') |
|
34 | - ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, cache entries will be flushed instead of deleted/invalidated.') |
|
35 | - ->setHelp(<<<'EOT' |
|
33 | + ->setDescription('Clear all query cache of the various cache drivers') |
|
34 | + ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, cache entries will be flushed instead of deleted/invalidated.') |
|
35 | + ->setHelp(<<<'EOT' |
|
36 | 36 | The <info>%command.name%</info> command is meant to clear the query cache of associated Entity Manager. |
37 | 37 | It is possible to invalidate all cache entries at once - called delete -, or flushes the cache provider |
38 | 38 | instance completely. |
@@ -49,7 +49,7 @@ discard block |
||
49 | 49 | Finally, be aware that if <info>--flush</info> option is passed, not all cache providers are able to flush entries, |
50 | 50 | because of a limitation of its execution nature. |
51 | 51 | EOT |
52 | - ); |
|
52 | + ); |
|
53 | 53 | } |
54 | 54 | |
55 | 55 | /** |
@@ -57,7 +57,7 @@ discard block |
||
57 | 57 | $em = $this->getHelper('em')->getEntityManager(); |
58 | 58 | $cacheDriver = $em->getConfiguration()->getQueryCacheImpl(); |
59 | 59 | |
60 | - if (! $cacheDriver) { |
|
60 | + if ( ! $cacheDriver) { |
|
61 | 61 | throw new InvalidArgumentException('No Query cache driver is configured on given EntityManager.'); |
62 | 62 | } |
63 | 63 | |
@@ -78,7 +78,7 @@ discard block |
||
78 | 78 | $message = $result ? 'Successfully flushed cache entries.' : $message; |
79 | 79 | } |
80 | 80 | |
81 | - if (! $result) { |
|
81 | + if ( ! $result) { |
|
82 | 82 | $ui->error($message); |
83 | 83 | |
84 | 84 | return 1; |
@@ -27,13 +27,13 @@ discard block |
||
27 | 27 | protected function configure() |
28 | 28 | { |
29 | 29 | $this->setName('orm:clear-cache:region:collection') |
30 | - ->setDescription('Clear a second-level cache collection region') |
|
31 | - ->addArgument('owner-class', InputArgument::OPTIONAL, 'The owner entity name.') |
|
32 | - ->addArgument('association', InputArgument::OPTIONAL, 'The association collection name.') |
|
33 | - ->addArgument('owner-id', InputArgument::OPTIONAL, 'The owner identifier.') |
|
34 | - ->addOption('all', null, InputOption::VALUE_NONE, 'If defined, all entity regions will be deleted/invalidated.') |
|
35 | - ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, all cache entries will be flushed.') |
|
36 | - ->setHelp(<<<'EOT' |
|
30 | + ->setDescription('Clear a second-level cache collection region') |
|
31 | + ->addArgument('owner-class', InputArgument::OPTIONAL, 'The owner entity name.') |
|
32 | + ->addArgument('association', InputArgument::OPTIONAL, 'The association collection name.') |
|
33 | + ->addArgument('owner-id', InputArgument::OPTIONAL, 'The owner identifier.') |
|
34 | + ->addOption('all', null, InputOption::VALUE_NONE, 'If defined, all entity regions will be deleted/invalidated.') |
|
35 | + ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, all cache entries will be flushed.') |
|
36 | + ->setHelp(<<<'EOT' |
|
37 | 37 | The <info>%command.name%</info> command is meant to clear a second-level cache collection regions for an associated Entity Manager. |
38 | 38 | It is possible to delete/invalidate all collection region, a specific collection region or flushes the cache provider. |
39 | 39 | |
@@ -57,7 +57,7 @@ discard block |
||
57 | 57 | Finally, be aware that if <info>--flush</info> option is passed, |
58 | 58 | not all cache providers are able to flush entries, because of a limitation of its execution nature. |
59 | 59 | EOT |
60 | - ); |
|
60 | + ); |
|
61 | 61 | } |
62 | 62 | |
63 | 63 | /** |
@@ -75,7 +75,7 @@ discard block |
||
75 | 75 | $ownerId = $input->getArgument('owner-id'); |
76 | 76 | $cache = $em->getCache(); |
77 | 77 | |
78 | - if (! $cache instanceof Cache) { |
|
78 | + if ( ! $cache instanceof Cache) { |
|
79 | 79 | throw new InvalidArgumentException('No second-level cache is configured on the given EntityManager.'); |
80 | 80 | } |
81 | 81 | |
@@ -86,7 +86,7 @@ discard block |
||
86 | 86 | if ($input->getOption('flush')) { |
87 | 87 | $collectionRegion = $cache->getCollectionCacheRegion($ownerClass, $assoc); |
88 | 88 | |
89 | - if (! $collectionRegion instanceof DefaultRegion) { |
|
89 | + if ( ! $collectionRegion instanceof DefaultRegion) { |
|
90 | 90 | throw new InvalidArgumentException(sprintf( |
91 | 91 | 'The option "--flush" expects a "Doctrine\ORM\Cache\Region\DefaultRegion", but got "%s".', |
92 | 92 | is_object($collectionRegion) ? get_class($collectionRegion) : gettype($collectionRegion) |
@@ -30,9 +30,9 @@ discard block |
||
30 | 30 | protected function configure() |
31 | 31 | { |
32 | 32 | $this->setName('orm:clear-cache:result') |
33 | - ->setDescription('Clear all result cache of the various cache drivers') |
|
34 | - ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, cache entries will be flushed instead of deleted/invalidated.') |
|
35 | - ->setHelp(<<<'EOT' |
|
33 | + ->setDescription('Clear all result cache of the various cache drivers') |
|
34 | + ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, cache entries will be flushed instead of deleted/invalidated.') |
|
35 | + ->setHelp(<<<'EOT' |
|
36 | 36 | The <info>%command.name%</info> command is meant to clear the result cache of associated Entity Manager. |
37 | 37 | It is possible to invalidate all cache entries at once - called delete -, or flushes the cache provider |
38 | 38 | instance completely. |
@@ -49,7 +49,7 @@ discard block |
||
49 | 49 | Finally, be aware that if <info>--flush</info> option is passed, not all cache providers are able to flush entries, |
50 | 50 | because of a limitation of its execution nature. |
51 | 51 | EOT |
52 | - ); |
|
52 | + ); |
|
53 | 53 | } |
54 | 54 | |
55 | 55 | /** |
@@ -57,7 +57,7 @@ discard block |
||
57 | 57 | $em = $this->getHelper('em')->getEntityManager(); |
58 | 58 | $cacheDriver = $em->getConfiguration()->getResultCacheImpl(); |
59 | 59 | |
60 | - if (! $cacheDriver) { |
|
60 | + if ( ! $cacheDriver) { |
|
61 | 61 | throw new InvalidArgumentException('No Result cache driver is configured on given EntityManager.'); |
62 | 62 | } |
63 | 63 | |
@@ -79,7 +79,7 @@ discard block |
||
79 | 79 | $message = $result ? 'Successfully flushed cache entries.' : $message; |
80 | 80 | } |
81 | 81 | |
82 | - if (! $result) { |
|
82 | + if ( ! $result) { |
|
83 | 83 | $ui->error($message); |
84 | 84 | |
85 | 85 | return 1; |
@@ -27,12 +27,12 @@ discard block |
||
27 | 27 | protected function configure() |
28 | 28 | { |
29 | 29 | $this->setName('orm:clear-cache:region:entity') |
30 | - ->setDescription('Clear a second-level cache entity region') |
|
31 | - ->addArgument('entity-class', InputArgument::OPTIONAL, 'The entity name.') |
|
32 | - ->addArgument('entity-id', InputArgument::OPTIONAL, 'The entity identifier.') |
|
33 | - ->addOption('all', null, InputOption::VALUE_NONE, 'If defined, all entity regions will be deleted/invalidated.') |
|
34 | - ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, all cache entries will be flushed.') |
|
35 | - ->setHelp(<<<'EOT' |
|
30 | + ->setDescription('Clear a second-level cache entity region') |
|
31 | + ->addArgument('entity-class', InputArgument::OPTIONAL, 'The entity name.') |
|
32 | + ->addArgument('entity-id', InputArgument::OPTIONAL, 'The entity identifier.') |
|
33 | + ->addOption('all', null, InputOption::VALUE_NONE, 'If defined, all entity regions will be deleted/invalidated.') |
|
34 | + ->addOption('flush', null, InputOption::VALUE_NONE, 'If defined, all cache entries will be flushed.') |
|
35 | + ->setHelp(<<<'EOT' |
|
36 | 36 | The <info>%command.name%</info> command is meant to clear a second-level cache entity region for an associated Entity Manager. |
37 | 37 | It is possible to delete/invalidate all entity region, a specific entity region or flushes the cache provider. |
38 | 38 | |
@@ -56,7 +56,7 @@ discard block |
||
56 | 56 | Finally, be aware that if <info>--flush</info> option is passed, |
57 | 57 | not all cache providers are able to flush entries, because of a limitation of its execution nature. |
58 | 58 | EOT |
59 | - ); |
|
59 | + ); |
|
60 | 60 | } |
61 | 61 | |
62 | 62 | /** |
@@ -73,18 +73,18 @@ |
||
73 | 73 | $entityId = $input->getArgument('entity-id'); |
74 | 74 | $cache = $em->getCache(); |
75 | 75 | |
76 | - if (! $cache instanceof Cache) { |
|
76 | + if ( ! $cache instanceof Cache) { |
|
77 | 77 | throw new InvalidArgumentException('No second-level cache is configured on the given EntityManager.'); |
78 | 78 | } |
79 | 79 | |
80 | - if (! $entityClass && ! $input->getOption('all')) { |
|
80 | + if ( ! $entityClass && ! $input->getOption('all')) { |
|
81 | 81 | throw new InvalidArgumentException('Invalid argument "--entity-class"'); |
82 | 82 | } |
83 | 83 | |
84 | 84 | if ($input->getOption('flush')) { |
85 | 85 | $entityRegion = $cache->getEntityCacheRegion($entityClass); |
86 | 86 | |
87 | - if (! $entityRegion instanceof DefaultRegion) { |
|
87 | + if ( ! $entityRegion instanceof DefaultRegion) { |
|
88 | 88 | throw new InvalidArgumentException(sprintf( |
89 | 89 | 'The option "--flush" expects a "Doctrine\ORM\Cache\Region\DefaultRegion", but got "%s".', |
90 | 90 | is_object($entityRegion) ? get_class($entityRegion) : gettype($entityRegion) |
@@ -20,11 +20,11 @@ discard block |
||
20 | 20 | public function testMixedParametersWithZeroNumber() : void |
21 | 21 | { |
22 | 22 | $query = $this->em->createQueryBuilder() |
23 | - ->select('u') |
|
24 | - ->from(CmsUser::class, 'u') |
|
25 | - ->andWhere('u.username = :username') |
|
26 | - ->andWhere('u.id = ?0') |
|
27 | - ->getQuery(); |
|
23 | + ->select('u') |
|
24 | + ->from(CmsUser::class, 'u') |
|
25 | + ->andWhere('u.username = :username') |
|
26 | + ->andWhere('u.id = ?0') |
|
27 | + ->getQuery(); |
|
28 | 28 | |
29 | 29 | $query->setParameter('username', 'bar'); |
30 | 30 | $query->setParameter(0, 0); |
@@ -39,13 +39,13 @@ discard block |
||
39 | 39 | public function testMixedParametersWithZeroNumberOnQueryBuilder() : void |
40 | 40 | { |
41 | 41 | $query = $this->em->createQueryBuilder() |
42 | - ->select('u') |
|
43 | - ->from(CmsUser::class, 'u') |
|
44 | - ->andWhere('u.username = :username') |
|
45 | - ->andWhere('u.id = ?0') |
|
46 | - ->setParameter('username', 'bar') |
|
47 | - ->setParameter(0, 0) |
|
48 | - ->getQuery(); |
|
42 | + ->select('u') |
|
43 | + ->from(CmsUser::class, 'u') |
|
44 | + ->andWhere('u.username = :username') |
|
45 | + ->andWhere('u.id = ?0') |
|
46 | + ->setParameter('username', 'bar') |
|
47 | + ->setParameter(0, 0) |
|
48 | + ->getQuery(); |
|
49 | 49 | |
50 | 50 | $query->execute(); |
51 | 51 |
@@ -247,7 +247,7 @@ |
||
247 | 247 | |
248 | 248 | // 2) Build insert table records into temporary table |
249 | 249 | $dql = ' SELECT t0.' . implode(', t0.', $rootClass->getIdentifierFieldNames()) |
250 | - . ' FROM ' . $targetClass->getClassName() . ' t0 WHERE t0.' . $association->getMappedBy() . ' = :owner'; |
|
250 | + . ' FROM ' . $targetClass->getClassName() . ' t0 WHERE t0.' . $association->getMappedBy() . ' = :owner'; |
|
251 | 251 | $query = $this->em->createQuery($dql)->setParameter('owner', $collection->getOwner()); |
252 | 252 | |
253 | 253 | $statement = 'INSERT INTO ' . $tempTable . ' (' . $idColumnNameList . ') ' . $query->getSQL(); |
@@ -33,7 +33,7 @@ discard block |
||
33 | 33 | // the entire collection with a new would trigger this operation. |
34 | 34 | $association = $collection->getMapping(); |
35 | 35 | |
36 | - if (! $association->isOrphanRemoval()) { |
|
36 | + if ( ! $association->isOrphanRemoval()) { |
|
37 | 37 | // Handling non-orphan removal should never happen, as @OneToMany |
38 | 38 | // can only be inverse side. For owning side one to many, it is |
39 | 39 | // required to have a join table, which would classify as a ManyToManyPersister. |
@@ -65,7 +65,7 @@ discard block |
||
65 | 65 | { |
66 | 66 | $association = $collection->getMapping(); |
67 | 67 | |
68 | - if (! ($association instanceof ToManyAssociationMetadata && $association->getIndexedBy())) { |
|
68 | + if ( ! ($association instanceof ToManyAssociationMetadata && $association->getIndexedBy())) { |
|
69 | 69 | throw new BadMethodCallException('Selecting a collection by index is only supported on indexed collections.'); |
70 | 70 | } |
71 | 71 | |
@@ -114,7 +114,7 @@ discard block |
||
114 | 114 | { |
115 | 115 | $association = $collection->getMapping(); |
116 | 116 | |
117 | - if (! ($association instanceof ToManyAssociationMetadata && $association->getIndexedBy())) { |
|
117 | + if ( ! ($association instanceof ToManyAssociationMetadata && $association->getIndexedBy())) { |
|
118 | 118 | throw new BadMethodCallException('Selecting a collection by index is only supported on indexed collections.'); |
119 | 119 | } |
120 | 120 | |
@@ -136,7 +136,7 @@ discard block |
||
136 | 136 | */ |
137 | 137 | public function contains(PersistentCollection $collection, $element) |
138 | 138 | { |
139 | - if (! $this->isValidEntityState($element)) { |
|
139 | + if ( ! $this->isValidEntityState($element)) { |
|
140 | 140 | return false; |
141 | 141 | } |
142 | 142 | |
@@ -160,12 +160,12 @@ discard block |
||
160 | 160 | { |
161 | 161 | $association = $collection->getMapping(); |
162 | 162 | |
163 | - if (! $association->isOrphanRemoval()) { |
|
163 | + if ( ! $association->isOrphanRemoval()) { |
|
164 | 164 | // no-op: this is not the owning side, therefore no operations should be applied |
165 | 165 | return false; |
166 | 166 | } |
167 | 167 | |
168 | - if (! $this->isValidEntityState($element)) { |
|
168 | + if ( ! $this->isValidEntityState($element)) { |
|
169 | 169 | return false; |
170 | 170 | } |
171 | 171 | |
@@ -203,7 +203,7 @@ discard block |
||
203 | 203 | } |
204 | 204 | |
205 | 205 | $tableName = $targetClass->table->getQuotedQualifiedName($this->platform); |
206 | - $statement = 'DELETE FROM ' . $tableName . ' WHERE ' . implode(' = ? AND ', $columns) . ' = ?'; |
|
206 | + $statement = 'DELETE FROM '.$tableName.' WHERE '.implode(' = ? AND ', $columns).' = ?'; |
|
207 | 207 | |
208 | 208 | return $this->conn->executeUpdate($statement, $parameters); |
209 | 209 | } |
@@ -240,17 +240,17 @@ discard block |
||
240 | 240 | ]; |
241 | 241 | } |
242 | 242 | |
243 | - $statement = $this->platform->getCreateTemporaryTableSnippetSQL() . ' ' . $tempTable |
|
244 | - . ' (' . $this->platform->getColumnDeclarationListSQL($columnDefinitions) . ')'; |
|
243 | + $statement = $this->platform->getCreateTemporaryTableSnippetSQL().' '.$tempTable |
|
244 | + . ' ('.$this->platform->getColumnDeclarationListSQL($columnDefinitions).')'; |
|
245 | 245 | |
246 | 246 | $this->conn->executeUpdate($statement); |
247 | 247 | |
248 | 248 | // 2) Build insert table records into temporary table |
249 | - $dql = ' SELECT t0.' . implode(', t0.', $rootClass->getIdentifierFieldNames()) |
|
250 | - . ' FROM ' . $targetClass->getClassName() . ' t0 WHERE t0.' . $association->getMappedBy() . ' = :owner'; |
|
249 | + $dql = ' SELECT t0.'.implode(', t0.', $rootClass->getIdentifierFieldNames()) |
|
250 | + . ' FROM '.$targetClass->getClassName().' t0 WHERE t0.'.$association->getMappedBy().' = :owner'; |
|
251 | 251 | $query = $this->em->createQuery($dql)->setParameter('owner', $collection->getOwner()); |
252 | 252 | |
253 | - $statement = 'INSERT INTO ' . $tempTable . ' (' . $idColumnNameList . ') ' . $query->getSQL(); |
|
253 | + $statement = 'INSERT INTO '.$tempTable.' ('.$idColumnNameList.') '.$query->getSQL(); |
|
254 | 254 | $parameters = array_values($sourcePersister->getIdentifier($collection->getOwner())); |
255 | 255 | $numDeleted = $this->conn->executeUpdate($statement, $parameters); |
256 | 256 | |
@@ -265,7 +265,7 @@ discard block |
||
265 | 265 | // 4) Delete records on each table in the hierarchy |
266 | 266 | $hierarchyClasses = array_merge( |
267 | 267 | array_map( |
268 | - function ($className) { |
|
268 | + function($className) { |
|
269 | 269 | return $this->em->getClassMetadata($className); |
270 | 270 | }, |
271 | 271 | array_reverse($targetClass->getSubClasses()) |