> drupal 8的實體查詢API:綜合指南
>> drupal 8從EntityFieldQuery(Drupal 7)過渡到用於查詢實體的更強大的服務。通過靜態調用或依賴注入訪問該服務,使用條件方法促進了複雜的查詢。 本指南探討了其功能。 entity.query
entity.query
> execute()
entity_load()
存在訪問服務的兩種方法:entity_load_multiple()
>
entity.query
>
2。依賴注入(推薦):
$query = \Drupal::entityQuery('node');
>
構建查詢以下是證明查詢結構的示例:
$entity_query_service = $container->get('entity.query'); $query = $entity_query_service->get('node');
>
>包含一個節點ID的數組。>
>此檢索在當前時間之前修改的已發表的節點,標題中包含“貓”,並在
$query = \Drupal::entityQuery('node') ->condition('status', 1); $nids = $query->execute();
$nids
>條件組(和/或):
這使用>找到匹配標題或標籤條件的節點。
也可用。$query = \Drupal::entityQuery('node') ->condition('status', 1) ->condition('changed', REQUEST_TIME, '<') ->condition('title', 'cat', 'CONTAINS') ->condition('field_tags.entity.name', 'cats'); $nids = $query->execute();
加載實體field_tags
field_tags.entity.name
執行查詢後,使用這些功能加載實體:
>單實體:
$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();
多個實體:orConditionGroup
andConditionGroup
結論
Drupal 8的實體查詢API對其前任提供了重大改進。 其面向對象的方法和靈活條件方法使開發人員能夠構建複雜的實體查詢。 記住要利用依賴注入以進行更好的代碼實踐。
以上是Drupal 8版本的EntityFieldQuery的詳細內容。更多資訊請關注PHP中文網其他相關文章!