function hook_query_TAG_alter
Same name in other branches
- 7.x modules/system/system.api.php \hook_query_TAG_alter()
- 8.9.x core/lib/Drupal/Core/Database/database.api.php \hook_query_TAG_alter()
- 10 core/lib/Drupal/Core/Database/database.api.php \hook_query_TAG_alter()
- 11.x core/lib/Drupal/Core/Database/database.api.php \hook_query_TAG_alter()
Perform alterations to a structured query for a given tag.
Some common tags include:
- 'entity_reference': For queries that return entities that may be referenced by an entity reference field.
- ENTITY_TYPE . '_access': For queries of entities that will be displayed in a listing (e.g., from Views) and therefore require access control.
Parameters
$query: A Query object describing the composite parts of a SQL query.
See also
node_query_node_access_alter()
AlterableInterface
SelectInterface
Related topics
14 functions implement hook_query_TAG_alter()
Note: this list is generated by pattern matching, so it may include some functions that are not actually implementations of this hook.
- block_content_query_entity_reference_alter in core/
modules/ block_content/ block_content.module - Implements hook_query_TAG_alter().
- database_test_query_database_test_alter_remove_range_alter in core/
modules/ system/ tests/ modules/ database_test/ database_test.module - Implements hook_query_TAG_alter().
- entity_test_query_entity_test_access_alter in core/
modules/ system/ tests/ modules/ entity_test/ entity_test.module - Implements hook_query_entity_test_access_alter().
- field_test_query_efq_metadata_test_alter in core/
modules/ field/ tests/ modules/ field_test/ field_test.module - Implements hook_query_TAG_alter() for tag 'efq_metadata_test'.
- field_test_query_efq_table_prefixing_test_alter in core/
modules/ field/ tests/ modules/ field_test/ field_test.module - Implements hook_query_TAG_alter() for tag 'efq_table_prefixing_test'.
File
-
core/
lib/ Drupal/ Core/ Database/ database.api.php, line 460
Code
function hook_query_TAG_alter(Drupal\Core\Database\Query\AlterableInterface $query) {
// This is an example of a possible hook_query_media_access_alter()
// implementation. In other words, alter queries of media entities that
// require access control (have the 'media_access' query tag).
// Determine which media entities we want to remove from the query. In this
// example, we hard-code some media IDs.
$media_entities_to_hide = [
1,
3,
];
// In this example, we're only interested in applying our media access
// restrictions to SELECT queries. hook_media_access() can be used to apply
// access control to 'update' and 'delete' operations.
if (!$query instanceof SelectInterface) {
return;
}
// The tables in the query. This can include media entity tables and other
// tables. Tables might be joined more than once, with aliases.
$query_tables = $query->getTables();
// The tables belonging to media entity storage.
$table_mapping = \Drupal::entityTypeManager()->getStorage('media')
->getTableMapping();
$media_tables = $table_mapping->getTableNames();
// For each table in the query, if it's a media entity storage table, add a
// condition to filter out records belonging to a media entity that we wish
// to hide.
foreach ($query_tables as $alias => $info) {
// Skip over subqueries.
if ($info['table'] instanceof SelectInterface) {
continue;
}
$real_table_name = $info['table'];
if (in_array($real_table_name, $media_tables)) {
$query->condition("{$alias}.mid", $media_entities_to_hide, 'NOT IN');
}
}
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.