1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
<?php
declare(strict_types=1);
use Doctrine\ORM\Mapping\ClassMetadata;
use Doctrine\Tests\Models\Cache\Attraction;
use Doctrine\Tests\Models\Cache\State;
use Doctrine\Tests\Models\Cache\Travel;
$metadata->setInheritanceType(ClassMetadata::INHERITANCE_TYPE_NONE);
$metadata->setPrimaryTable(['name' => 'cache_city']);
$metadata->setIdGeneratorType(ClassMetadata::GENERATOR_TYPE_IDENTITY);
$metadata->setChangeTrackingPolicy(ClassMetadata::CHANGETRACKING_DEFERRED_IMPLICIT);
$metadata->enableCache(
[
'usage' => ClassMetadata::CACHE_USAGE_READ_ONLY,
]
);
$metadata->mapField(
[
'fieldName' => 'id',
'type' => 'integer',
'id' => true,
]
);
$metadata->mapField(
[
'fieldName' => 'name',
'type' => 'string',
]
);
$metadata->mapOneToOne(
[
'fieldName' => 'state',
'targetEntity' => State::class,
'inversedBy' => 'cities',
'joinColumns' =>
[
[
'name' => 'state_id',
'referencedColumnName' => 'id',
],
],
]
);
$metadata->enableAssociationCache('state', [
'usage' => ClassMetadata::CACHE_USAGE_READ_ONLY,
]);
$metadata->mapManyToMany(
[
'fieldName' => 'travels',
'targetEntity' => Travel::class,
'mappedBy' => 'visitedCities',
]
);
$metadata->mapOneToMany(
[
'fieldName' => 'attractions',
'targetEntity' => Attraction::class,
'mappedBy' => 'city',
'orderBy' => ['name' => 'ASC'],
]
);
$metadata->enableAssociationCache('attractions', [
'usage' => ClassMetadata::CACHE_USAGE_READ_ONLY,
]);
|