Heim > Backend-Entwicklung > PHP-Tutorial > Die Drupal 8 -Version von EntityFieldQuery

Die Drupal 8 -Version von EntityFieldQuery

Christopher Nolan
Freigeben: 2025-02-20 10:31:08
Original
394 Leute haben es durchsucht

Drupal 8's Entity Query API: Ein umfassendes Leitfaden

Drupal 8 überging von entityfieldQuery (Drupal 7) zum robusteren entity.query -Dienst für Abfrageberitäten. Dieser Service, der über statische Anrufe oder Abhängigkeitsinjektion zugänglich ist, erleichtert komplexe Abfragen mit Bedingungen. Dieser Leitfaden untersucht seine Fähigkeiten.

Schlüsselkonzepte

  • entity.query Service: Der Kern der Entitätsabfrage von Drupal 8. Erstellt Abfrageobjekte für bestimmte Entitätstypen (Knoten, Benutzer usw.).
  • Bedingungsmethoden: Filterung basierend auf Feldwerten, Klasseneigenschaften und Sprachcodes (Langcode).
  • .
  • execute() Methode:
  • Gibt ein Array von Entitäts -IDs zurück.
  • entity_load() entity_load_multiple()/:
  • Funktionen zum Laden einzelner oder mehrerer Entitäten mit ihren IDs.

entity.query Zugriff auf den

Service

Es gibt zwei Methoden zum Zugriff auf den Dienst:

1. Statischer Zugriff (weniger empfohlen):

$query = \Drupal::entityQuery('node');
Nach dem Login kopieren

Ersetzen Sie 'Knoten' durch den Maschinennamen des gewünschten Entitätstyps.

2. Abhängigkeitsinjektion (empfohlen):

$entity_query_service = $container->get('entity.query');
$query = $entity_query_service->get('node');
Nach dem Login kopieren

Dieser Ansatz wird für eine bessere Testbarkeit und Entkopplung bevorzugt.

Erstellen von Abfragen

Hier sind Beispiele, die die Abfragekonstruktion demonstrieren:

Einfache Abfrage (veröffentlichte Knoten):

$query = \Drupal::entityQuery('node')
  ->condition('status', 1);

$nids = $query->execute();
Nach dem Login kopieren

$nids

enthält ein Array von Knoten -IDs.

komplexe Abfrage (mehrere Bedingungen):

$query = \Drupal::entityQuery('node')
  ->condition('status', 1)
  ->condition('changed', REQUEST_TIME, '<')
  ->condition('title', 'cat', 'CONTAINS')
  ->condition('field_tags.entity.name', 'cats');

$nids = $query->execute();
Nach dem Login kopieren

field_tags Diese abgerufener Knoten, die vor der aktuellen Zeit modifiziert wurden, enthielten "Katze" im Titel und verweisen auf die Taxonomie -Taxonomie in field_tags.entity.name. Beachten Sie die Behandlung von referenzierten Entitäten (

).

Zustandsgruppen (und/oder):

$query = \Drupal::entityQuery('node')
  ->condition('status', 1)
  ->condition('changed', REQUEST_TIME, '<');

$group = $query->orConditionGroup()
  ->condition('title', 'cat', 'CONTAINS')
  ->condition('field_tags.entity.name', 'cats');

$nids = $query->condition($group)->execute();
Nach dem Login kopieren

orConditionGroup Dies verwendet ein andConditionGroup, um Knoten zu finden, die entweder den Titel- oder Tag -Zustand entsprechen.

ist ebenfalls verfügbar.

Ladeeinheiten

Verwenden Sie nach Ausführung einer Abfrage diese Funktionen, um Entitäten zu laden:

Einzeleinheit:

$node = entity_load('node', $nids[0]);
Nach dem Login kopieren

Mehrere Entitäten:

$nodes = entity_load_multiple('node', $nids);
Nach dem Login kopieren

Diese Funktionen sind Wrapper für den Entity Storage Manager. Direktzugriff über den Storage Manager ist auch mit Abhängigkeitsinjektion möglich:
$node_storage = $container->get('entity.manager')->getStorage('node');
$nodes = $node_storage->loadMultiple($nids);
Nach dem Login kopieren

Schlussfolgerung

Drupal 8's Entity Query API bietet eine signifikante Verbesserung gegenüber dem Vorgänger. Sein objektorientierter Ansatz und seine flexiblen Zustandsmethoden ermöglichen Entwicklern, anspruchsvolle Entitätsanfragen aufzubauen. Denken Sie daran, die Abhängigkeitsinjektion für bessere Codepraktiken zu verwenden.

The Drupal 8 version of EntityFieldQuery

Das obige ist der detaillierte Inhalt vonDie Drupal 8 -Version von EntityFieldQuery. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage