diff --git a/core/lib/Drupal/Core/Entity/Query/Sql/Tables.php b/core/lib/Drupal/Core/Entity/Query/Sql/Tables.php index b9b754b664630a192e5b1f4cc08ff3e3d5df649a..4fe64dbc62bddaf5994e4aad1e23a7508703b8c0 100644 --- a/core/lib/Drupal/Core/Entity/Query/Sql/Tables.php +++ b/core/lib/Drupal/Core/Entity/Query/Sql/Tables.php @@ -250,6 +250,14 @@ public function addField($field, $type, $langcode) { $key++; } } + // If there are no additional specifiers but the field has a main + // property, use that to look up the column name. + elseif ($field_storage && $column) { + $columns = $field_storage->getColumns(); + if (isset($columns[$column])) { + $sql_column = $table_mapping->getFieldColumnName($field_storage, $column); + } + } $table = $this->ensureEntityTable($index_prefix, $sql_column, $type, $langcode, $base_table, $entity_id_field, $entity_tables); } diff --git a/core/tests/Drupal/KernelTests/Core/Entity/EntityQueryTest.php b/core/tests/Drupal/KernelTests/Core/Entity/EntityQueryTest.php index 380f5b5263a9a0fd2871d468126c8bd67675ff5f..274d3c79f6cce46800f4c787df9656481915c214 100644 --- a/core/tests/Drupal/KernelTests/Core/Entity/EntityQueryTest.php +++ b/core/tests/Drupal/KernelTests/Core/Entity/EntityQueryTest.php @@ -975,7 +975,7 @@ public function testBaseFieldMultipleColumns() { 'name' => $this->randomMachineName(), 'vid' => 'tags', 'description' => [ - 'value' => $this->randomString(), + 'value' => 'description1', 'format' => 'format1', ], ]); @@ -985,20 +985,37 @@ public function testBaseFieldMultipleColumns() { 'name' => $this->randomMachineName(), 'vid' => 'tags', 'description' => [ - 'value' => $this->randomString(), + 'value' => 'description2', 'format' => 'format2', ], ]); $term2->save(); + // Test that the properties can be queried directly. + $ids = $this->container->get('entity_type.manager') + ->getStorage('taxonomy_term') + ->getQuery() + ->condition('description.value', 'description1') + ->execute(); + $this->assertCount(1, $ids); + $this->assertEquals($term1->id(), reset($ids)); + $ids = $this->container->get('entity_type.manager') ->getStorage('taxonomy_term') ->getQuery() ->condition('description.format', 'format1') ->execute(); + $this->assertCount(1, $ids); + $this->assertEquals($term1->id(), reset($ids)); + // Test that the main property is queried if no property is specified. + $ids = $this->container->get('entity_type.manager') + ->getStorage('taxonomy_term') + ->getQuery() + ->condition('description', 'description1') + ->execute(); $this->assertCount(1, $ids); - $this->assertEqual($term1->id(), reset($ids)); + $this->assertEquals($term1->id(), reset($ids)); } /**