You are browsing a version that has not yet been released. |
PHP Mapping
Doctrine ORM also allows you to provide the ORM metadata in the form of plain
PHP code using the ClassMetadata
API. You can write the code in inside of a
static function named loadMetadata($class)
on the entity class itself.
Static Function
In addition to other drivers using configuration languages you can also programatically specify your mapping information inside of a static function defined on the entity class itself.
This is useful for cases where you want to keep your entity and mapping
information together but don't want to use attributes. For this you just
need to use the StaticPHPDriver
:
Now you just need to define a static function named
loadMetadata($metadata)
on your entity:
1 <?php
namespace Entities;
use Doctrine\ORM\Mapping\ClassMetadata;
class User
{
// ...
public static function loadMetadata(ClassMetadata $metadata)
{
$metadata->mapField(array(
'id' => true,
'fieldName' => 'id',
'type' => 'integer'
));
$metadata->mapField(array(
'fieldName' => 'username',
'type' => 'string'
));
}
}
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
ClassMetadataBuilder
To ease the use of the ClassMetadata API (which is very raw) there is a ClassMetadataBuilder
that you can use.
1 <?php
namespace Entities;
use Doctrine\ORM\Mapping\ClassMetadata;
use Doctrine\ORM\Mapping\Builder\ClassMetadataBuilder;
class User
{
// ...
public static function loadMetadata(ClassMetadata $metadata)
{
$builder = new ClassMetadataBuilder($metadata);
$builder->createField('id', 'integer')->isPrimaryKey()->generatedValue()->build();
$builder->addField('username', 'string');
}
}
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
The API of the ClassMetadataBuilder has the following methods with a fluent interface:
-
addField($name, $type, array $mapping)
-
setMappedSuperclass()
-
setReadOnly()
-
setCustomRepositoryClass($className)
-
setTable($name)
-
addIndex(array $columns, $indexName)
-
addUniqueConstraint(array $columns, $constraintName)
-
setJoinedTableInheritance()
-
setSingleTableInheritance()
-
setDiscriminatorColumn($name, $type = 'string', $length = 255, $columnDefinition = null, $enumType = null)
-
addDiscriminatorMapClass($name, $class)
-
setChangeTrackingPolicyDeferredExplicit()
-
setChangeTrackingPolicyNotify()
-
addLifecycleEvent($methodName, $event)
-
addManyToOne($name, $targetEntity, $inversedBy = null)
-
addInverseOneToOne($name, $targetEntity, $mappedBy)
-
addOwningOneToOne($name, $targetEntity, $inversedBy = null)
-
addOwningManyToMany($name, $targetEntity, $inversedBy = null)
-
addInverseManyToMany($name, $targetEntity, $mappedBy)
-
addOneToMany($name, $targetEntity, $mappedBy)
It also has several methods that create builders (which are necessary for advanced mappings):
-
createField($name, $type)
returns aFieldBuilder
instance -
createManyToOne($name, $targetEntity)
returns anAssociationBuilder
instance -
createOneToOne($name, $targetEntity)
returns anAssociationBuilder
instance -
createManyToMany($name, $targetEntity)
returns anManyToManyAssociationBuilder
instance -
createOneToMany($name, $targetEntity)
returns anOneToManyAssociationBuilder
instance
ClassMetadata API
The ClassMetadata
class is the data object for storing the mapping
metadata for a single entity. It contains all the getters and setters
you need populate and retrieve information for an entity.
General Setters
-
setTableName($tableName)
-
setPrimaryTable(array $primaryTableDefinition)
-
setCustomRepositoryClass($repositoryClassName)
-
setIdGeneratorType($generatorType)
-
setIdGenerator($generator)
-
setSequenceGeneratorDefinition(array $definition)
-
setChangeTrackingPolicy($policy)
-
setIdentifier(array $identifier)
Inheritance Setters
-
setInheritanceType($type)
-
setSubclasses(array $subclasses)
-
setParentClasses(array $classNames)
-
setDiscriminatorColumn($columnDef)
-
setDiscriminatorMap(array $map)
Field Mapping Setters
-
mapField(array $mapping)
-
mapOneToOne(array $mapping)
-
mapOneToMany(array $mapping)
-
mapManyToOne(array $mapping)
-
mapManyToMany(array $mapping)
Lifecycle Callback Setters
-
addLifecycleCallback($callback, $event)
-
setLifecycleCallbacks(array $callbacks)
Identifier Getters
-
getIdentifierColumnNames()
-
usesIdGenerator()
-
isIdentifier($fieldName)
-
isIdGeneratorIdentity()
-
isIdGeneratorSequence()
-
isIdGeneratorTable()
-
isIdentifierNatural()
-
getIdentifierFieldNames()
-
getSingleIdentifierFieldName()
-
getSingleIdentifierColumnName()
Inheritance Getters
-
isInheritanceTypeNone()
-
isInheritanceTypeJoined()
-
isInheritanceTypeSingleTable()
-
isInheritedField($fieldName)
-
isInheritedAssociation($fieldName)
Change Tracking Getters
-
isChangeTrackingDeferredExplicit()
-
isChangeTrackingDeferredImplicit()
-
isChangeTrackingNotify()
Field & Association Getters
-
isUniqueField($fieldName)
-
isNullable($fieldName)
-
getColumnName($fieldName)
-
getFieldMapping($fieldName)
-
getAssociationMapping($fieldName)
-
getAssociationMappings()
-
getFieldName($columnName)
-
hasField($fieldName)
-
getColumnNames(array $fieldNames = null)
-
getTypeOfField($fieldName)
-
getTypeOfColumn($columnName)
-
hasAssociation($fieldName)
-
isSingleValuedAssociation($fieldName)
-
isCollectionValuedAssociation($fieldName)
Runtime reflection methods
These are methods related to runtime reflection for working with the entities themselves.
-
getReflectionClass()
-
getReflectionProperties()
-
getReflectionProperty($name)
-
getSingleIdReflectionProperty()
-
getIdentifierValues($entity)
-
setIdentifierValues($entity, $id)
-
setFieldValue($entity, $field, $value)
-
getFieldValue($entity, $field)