protected function SqlContentEntityStorageSchema::initializeDataTable in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/lib/Drupal/Core/Entity/Sql/SqlContentEntityStorageSchema.php \Drupal\Core\Entity\Sql\SqlContentEntityStorageSchema::initializeDataTable()
Initializes common information for a data table.
Parameters
\Drupal\Core\Entity\ContentEntityTypeInterface $entity_type: The entity type.
Return value
array A partial schema array for the data table.
1 call to SqlContentEntityStorageSchema::initializeDataTable()
- SqlContentEntityStorageSchema::getEntitySchema in core/
lib/ Drupal/ Core/ Entity/ Sql/ SqlContentEntityStorageSchema.php - Gets the entity schema for the specified entity type.
File
- core/
lib/ Drupal/ Core/ Entity/ Sql/ SqlContentEntityStorageSchema.php, line 916 - Contains \Drupal\Core\Entity\Sql\SqlContentEntityStorageSchema.
Class
- SqlContentEntityStorageSchema
- Defines a schema handler that supports revisionable, translatable entities.
Namespace
Drupal\Core\Entity\SqlCode
protected function initializeDataTable(ContentEntityTypeInterface $entity_type) {
$entity_type_id = $entity_type
->id();
$id_key = $entity_type
->getKey('id');
$schema = array(
'description' => "The data table for {$entity_type_id} entities.",
'primary key' => array(
$id_key,
$entity_type
->getKey('langcode'),
),
'indexes' => array(
$entity_type_id . '__id__default_langcode__langcode' => array(
$id_key,
$entity_type
->getKey('default_langcode'),
$entity_type
->getKey('langcode'),
),
),
'foreign keys' => array(
$entity_type_id => array(
'table' => $this->storage
->getBaseTable(),
'columns' => array(
$id_key => $id_key,
),
),
),
);
if ($entity_type
->hasKey('revision')) {
$key = $entity_type
->getKey('revision');
$schema['indexes'][$this
->getEntityIndexName($entity_type, $key)] = array(
$key,
);
}
$this
->addTableDefaults($schema);
return $schema;
}