X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;f=web%2Fcore%2Fmodules%2Fcomment%2Fsrc%2FCommentStorageSchema.php;fp=web%2Fcore%2Fmodules%2Fcomment%2Fsrc%2FCommentStorageSchema.php;h=2106a8ec2b85905c7dc5387e9d2cee948765f92e;hb=a2bd1bf0c2c1f1a17d188f4dc0726a45494cefae;hp=0000000000000000000000000000000000000000;hpb=57c063afa3f66b07c4bbddc2d6129a96d90f0aad;p=yaffs-website diff --git a/web/core/modules/comment/src/CommentStorageSchema.php b/web/core/modules/comment/src/CommentStorageSchema.php new file mode 100644 index 000000000..2106a8ec2 --- /dev/null +++ b/web/core/modules/comment/src/CommentStorageSchema.php @@ -0,0 +1,73 @@ + ['pid', 'status'], + 'comment__num_new' => [ + 'entity_id', + 'entity_type', + 'comment_type', + 'status', + 'created', + 'cid', + 'thread', + ], + 'comment__entity_langcode' => [ + 'entity_id', + 'entity_type', + 'comment_type', + 'default_langcode', + ], + ]; + + return $schema; + } + + /** + * {@inheritdoc} + */ + protected function getSharedTableFieldSchema(FieldStorageDefinitionInterface $storage_definition, $table_name, array $column_mapping) { + $schema = parent::getSharedTableFieldSchema($storage_definition, $table_name, $column_mapping); + $field_name = $storage_definition->getName(); + + if ($table_name == 'comment_field_data') { + // Remove unneeded indexes. + unset($schema['indexes']['comment_field__pid__target_id']); + unset($schema['indexes']['comment_field__entity_id__target_id']); + + switch ($field_name) { + case 'thread': + // Improves the performance of the comment__num_new index defined + // in getEntitySchema(). + $schema['fields'][$field_name]['not null'] = TRUE; + break; + + case 'created': + $this->addSharedTableFieldIndex($storage_definition, $schema, TRUE); + break; + + case 'uid': + $this->addSharedTableFieldForeignKey($storage_definition, $schema, 'users', 'uid'); + } + } + + return $schema; + } + +}