什么是正确使用EntityFieldQuery? -- 7 领域 和 database 领域 drupal 相关 的问题

What's the proper use of EntityFieldQuery?


37
vote

问题

中文

在drupal 7中, node_load_multiple() 使用 $conditions 参数指定的API文档已被弃用,支持使用 EntityFieldQuery 。如何使用该类来生成节点ID列表,以便与 node_load_multiple() 一起使用?是否有其他用例?

英文原文

In Drupal 7, the API documentation for node_load_multiple() specifies using the $conditions parameter has been deprecated in favor of using EntityFieldQuery. How does one use the class to generate a list of node IDs for use with node_load_multiple()? Are there any other use cases for it?

     

回答列表

36
 
vote
vote
最佳答案
 

EntityFieldQuery使用一组钩子与现场存储模块(例如字段SQL存储)接口,以便为字段以及其他节点属性工作。长期,EntityFieldQuery是一种更可靠的方式来查询任何类型的实体,在某些情况下,它可以执行跨实体查询(请参阅 field_has_data 或 _ list_values_in_USE()有关示例。

这是一个简单的例子,它使用EntityFieldQuery获取特定时间戳前发布的所有节点列表:

  $query = new EntityFieldQuery();  $query   ->entityCondition('entity_type', 'node', '=')   ->propertyCondition('status', 1, '=')   ->propertyCondition('created', '1294694496', '<');  $result = $query->execute();   

$结果来自该查询看起来像这样的东西:

  Array (     [node] => Array         (             [1] => stdClass Object                 (                     [nid] => 1                     [vid] => 49                     [type] => article                 )              [2] => stdClass Object                 (                     [nid] => 2                     [vid] => 2                     [type] => page                 )          )  )   
然后,您可以使用该数组作为输入到Node_load_Multiple:
  $nodes = node_load_multiple(array_keys($result['node']));   
 

EntityFieldQuery uses a set of hooks to interface with field storage modules, such as Field SQL Storage, in order to work for fields as well as other node properties. Long term, EntityFieldQuery is a much more reliable way to query any type of entity, and in some situations it can perform cross entity queries (see field_has_data or _list_values_in_use() for an example.

Here's a simple example of using EntityFieldQuery to get a list of all nodes published before a specific timestamp:

$query = new EntityFieldQuery();  $query   ->entityCondition('entity_type', 'node', '=')   ->propertyCondition('status', 1, '=')   ->propertyCondition('created', '1294694496', '<');  $result = $query->execute(); 

$results from that query would look something like this:

Array (     [node] => Array         (             [1] => stdClass Object                 (                     [nid] => 1                     [vid] => 49                     [type] => article                 )              [2] => stdClass Object                 (                     [nid] => 2                     [vid] => 2                     [type] => page                 )          )  ) 

You could then use that array as input to node_load_multiple:

$nodes = node_load_multiple(array_keys($result['node'])); 
 
 
 
 
14
 
vote

我在drupal上发现了一个关于为 EntityFieldQuery 的例子添加示例的问题。我一直在使用它来举例说明以及更多示例的呼叫语音。

"我们需要一个EntityFieldQuery示例吗?"

评论#11 显示 node_load_multiple() 的用法如下所示:

  $query = new EntityFieldQuery(); $entities = $query->entityCondition('entity_type', 'node')                         ->entityCondition('bundle', 'event')                         ->propertyCondition('status', 1)                         ->fieldCondition('field_date', 'value', array('2011-03-01', '2011-03-31'), 'BETWEEN')                         ->fieldOrderBy('field_date', 'value', 'ASC')                         ->execute();  $nodes = entity_load('node', array_keys($entities['node'])); return node_view_multiple($nodes, 'teaser');   
 

I found an issue on Drupal about adding examples for EntityFieldQuery. I've been using it for examples as well as to voice my opinion on the call for more examples.

"Do we need an EntityFieldQuery example?"

The comment #11 shows usage of node_load_multiple() as seen below:

$query = new EntityFieldQuery(); $entities = $query->entityCondition('entity_type', 'node')                         ->entityCondition('bundle', 'event')                         ->propertyCondition('status', 1)                         ->fieldCondition('field_date', 'value', array('2011-03-01', '2011-03-31'), 'BETWEEN')                         ->fieldOrderBy('field_date', 'value', 'ASC')                         ->execute();  $nodes = entity_load('node', array_keys($entities['node'])); return node_view_multiple($nodes, 'teaser'); 
 
 
 
 
8
 
vote

以下是其中一个测试模块的示例:

http://api.drupal。 ORG / API / DRUPAL / MODULES - 节点 - 测试 - node_access_test.module / function / node_access_entity_test_page / 7

这选择身体字段以"A" 开头的节点。另请参见 EntityFieldQuery :: Execute() On如何使用返回的结果。

有很多用例,典型示例是查询特定字段值的实体,如第一个示例中所示。

优势在于它适用于您正在使用的任何Field_Storage。例如,您可以在MongoDB中拥有您的字段,并且entityQuery将手动查询Field_Data_Body的同时仍然工作。

 

Here is an example from one of the test modules:

http://api.drupal.org/api/drupal/modules--node--tests--node_access_test.module/function/node_access_entity_test_page/7

This selects nodes whose body field starts with "A". See also EntityFieldQuery::execute() on how to use the returned result.

There are many use cases, the typical example is querying entities for specific field value like the body field as shown in the first example.

The advantage is that it works whatever field_storage you are using. For example, you can have your fields in MongoDB and EntityQuery will still work while querying field_data_body manually wouldn't.

 
 
0
 
vote

您可以使用 EntityFieldQuery 类查询数据库并以类似于 <代码> node_load_multiple()

这可以通过创建类,应用条件和执行查询来实现,例如:

  <?php $query = new EntityFieldQuery(); $query   ->entityCondition('entity_type', 'TYPE') // E.g. node, entityform, taxonomy_term   ->entityCondition('bundle', 'BUNDLE')   ->fieldCondition('field_foo', 'value', 'STRING')   ->range(0,10); $result = $query->execute(); ?>   

这将生成阵列,如:

  array (   'TYPE' =>   array (     123 =>     stdClass::__set_state(array(        'nid' => '123', // Can be also tid when loading terms.        'key' => 'value',     )),     456 =>     stdClass::__set_state(array(        'nid' => '456',        'key' => 'value',     )),   ), )   

从结果数组获取ID,您可以使用: current(current($result))->tid

这里是更高级的示例:

  <?php $query = new EntityFieldQuery();  $query->entityCondition('entity_type', 'node')   ->entityCondition('bundle', 'article')   ->propertyCondition('status', NODE_PUBLISHED)   ->fieldCondition('field_news_types', 'value', 'spotlight', '=')   ->fieldCondition('field_photo', 'fid', 'NULL', '!=')   ->fieldCondition('field_faculty_tag', 'tid', $value)   ->fieldCondition('field_news_publishdate', 'value', $year . '%', 'like')   ->fieldOrderBy('field_photo', 'fid', 'DESC')   ->range(0, 10)   ->addMetaData('account', user_load(1)); // Run the query as user 1.  $result = $query->execute();  if (isset($result['node'])) {   $news_items_nids = array_keys($result['node']);   $news_items = entity_load('node', $news_items_nids); } ?>   

请参阅:如何在drupal.org处使用entityfieldquery 以获取更多解释。

 

You can use EntityFieldQuery class to query the database and fetch the results in form of list similar to node_load_multiple().

This can be achieved by creating a class, applying the conditions and executing the query, for example:

<?php $query = new EntityFieldQuery(); $query   ->entityCondition('entity_type', 'TYPE') // E.g. node, entityform, taxonomy_term   ->entityCondition('bundle', 'BUNDLE')   ->fieldCondition('field_foo', 'value', 'STRING')   ->range(0,10); $result = $query->execute(); ?> 

This will generate the array such like:

array (   'TYPE' =>   array (     123 =>     stdClass::__set_state(array(        'nid' => '123', // Can be also tid when loading terms.        'key' => 'value',     )),     456 =>     stdClass::__set_state(array(        'nid' => '456',        'key' => 'value',     )),   ), ) 

To fetch the ID from the result array, you can use: current(current($result))->tid.

Here is more advanced example:

<?php $query = new EntityFieldQuery();  $query->entityCondition('entity_type', 'node')   ->entityCondition('bundle', 'article')   ->propertyCondition('status', NODE_PUBLISHED)   ->fieldCondition('field_news_types', 'value', 'spotlight', '=')   ->fieldCondition('field_photo', 'fid', 'NULL', '!=')   ->fieldCondition('field_faculty_tag', 'tid', $value)   ->fieldCondition('field_news_publishdate', 'value', $year . '%', 'like')   ->fieldOrderBy('field_photo', 'fid', 'DESC')   ->range(0, 10)   ->addMetaData('account', user_load(1)); // Run the query as user 1.  $result = $query->execute();  if (isset($result['node'])) {   $news_items_nids = array_keys($result['node']);   $news_items = entity_load('node', $news_items_nids); } ?> 

See: How to use EntityFieldQuery at Drupal.org for more explanation.

 
 

相关问题

90  是否会影响未启用的模块会影响性能?  ( Do non enabled modules affect performance ) 
具有垂直模块,但未使能对Drupal站点的性能有任何影响? 要换句话说,将删除Drupal站点上的禁用模块对性能有正影响? ...

9  如何加载WYSIWYG API插件所需的额外JavaScript文件,在节点/编辑页面上?  ( How do you load extra javascript files required for wysiwyg api plugin on node e ) 
我正在使用WYSIWYG API模块为Drupal 7构建插件,该模块将为支持的编辑器的工具栏添加一个按钮。 我正在使用 hook_wysiwyg_plugin() 挂钩在编辑器工具栏上创建一个新的按钮,但我需要加载其他一些JavaScript文件。 hook_wysiwyg_plugin() 钩子似乎允许您指定...

6  如何确定当前页面是否是搜索结果页面?  ( How to determine if the current page is a search results page ) 
如果当前页面是Apache Solr搜索结果页面,我如何在模块或主题中确定? ...

5  重建ImageCache  ( Rebuild imagecache ) 
我每个节点有一个图像域,它通过ImageCache运行。由于ImageCache缓存按需,因此在首次请求之前不会创建缓存文件/变体。因此,如果我更新一堆图像,重新部署或以其他方式吹整个缓存,这取决于第一个访问该文件的访问者。 如何才能备用用户加载时间并手动重建整个缓存? 最后一次提出来,我以编程方式加载了与jQu...

3  视图2条件过滤器  ( Views 2 conditional filter ) 
如何将条件安装程序应用于视图(使用视图2)? 例如: 我有一个视图,它使用节点上的过滤器显示多个不同节点类型的预告:[博客条目,论坛主题,用户配置文件] 这适用于显示这些类型的所有节点,但假设我只想显示用户的个人资料,如果它也有图片(以及所有其他类型)。 ...

3  是否有一个可以处理MIDI文件的媒体处理模块?  ( Is there a media handling module that can handle midi files ) 
我一直在使用 mp3播放器提供一个页面mp3播放器,但我也需要能够处理MIDI文件。现在我可以做的最好的就是允许它们上传到"MP3文件" 字段中,但是当它呈现节点时,它只是给出了文件的链接,这意味着您必须导航到文件(或打开它在一个新标签中,浏览器播放它。 ...

5  删除用户时会导致站点挂起的内容?  ( What can cause a site to hang when deleting a user ) 
当我尝试删除用户时,整个站点挂起,即drupal不再响应了。什么会导致它? 该站点没有安装任何特殊的用户配置文件模块。 编辑: 只有一个自定义(自制)模块,带有Hook_User,它打开 $op 。 "删除" 案例外观未验证: case 'delete': $sql = "DELETE FROM {m...

16  如何在Drupal 7的一页上获得超过10个搜索结果?  ( How can i get more than 10 search results on one page in drupal 7 ) 
默认搜索页面仅显示10个结果。如何更改它以显示无限数量的结果? ...

6  从视图中重复分类分类术语  ( Duplicate taxonomy terms from view ) 
所以我尚未能够找到解决方案,而无需使用预处理函数来检查重复或仅使用"标签" 模块。很好,可以封闭。 如何配置(块)视图以显示词汇表的术语列表,每个术语显示一次(也许是指示它使用的次数的数字) - 即使术语可以由多个节点? "截然不同" 没有工作..字段'分类:所有术语'和'分类:术语'都会产生类似的重复项目,当该术...

80  任何方法为单页/节点添加CSS?  ( Any way to add css for a single page node ) 
我正在清理我的大疯狂风格的表格(可能与未来的问题有关),我想知道将自定义CSS添加到特定节点或页面的最佳方法。 特别是,我的工作网站的主页是面板页面,它有一堆不同的造型。现在,CSS刚刚包含在主题样式表中。 有没有办法说,"如果这是节点foo,则添加foo.css" ?是 css注射器我正在寻找什么? i 可能对其...

12  如何管理Drupal网站上的协作发展?  ( How do i manage collaborative development on a drupal site ) 
我在Drupal网站上使用另一个开发人员。我们一直在努力在没有彼此的情况下同时找到在网站的不同部分工作的好方法。我们已经尝试过在网站的同一开发实例上工作,但我们经常踩到其他人脚趾,或者用一些不好的代码延续网站,使其无法继续工作,直到它得到解决。所以我们搬到了分开的开发实例。但现在将我们的工作合并到网站的单一实例中是一...

4  如何使用子主题覆盖主题的Template.php的单一函数?  ( How to override single function of themes template php using sub theme ) 
目标: drupal 7子主题开发 我不想覆盖整个template.php文件。我只是想覆盖template.php文件的单一函数。 ...

5  使用数据库的良好做法  ( Good practices working with databases ) 
我正在学习drupal,我想开发一个网站,主要是它的数据库。 我已经拥有数据库的扩展实体关系模型(类型的复杂)。 在创建要由drupal使用的数据库时,采取的正确方向是什么,创建它手动,并使用php在drupal中进行查询,因为它是从头开始的php + mysql站点? Drupal是否提供了更容易的方法来做这件事?...

17  如何在有多个功能有多个功能时选择要使用的模块?  ( How do i choose which module to use when there are several options for the same ) 
它并不罕见,找到提供基本相同的功能的多个模块。例如,有许多垃圾邮件控制模块提供极为相似的功能(例如, spamicide 和)。并且有很多不同的分类模块可以做类似的事情。因此,当多个模块满足我的要求时,我应该如何选择使用哪一个? ...

5  如何每次查看节点时执行操作?  ( How to perform an operation every time a node is viewed ) 
在编写模块时,我如何每次用户查看节点时执行一次操作? ...

0  如何生成一个列表,其中包含哪些空格?  ( How to generate a list of which features are enabled in which spaces ) 
我正在使用有机组,特征和空格运行一个Drupal 6.x站点,我对生成一个空格启用的空格的列表有兴趣。优选地,具有沿Y轴的空间的表,以及沿X轴的特征。 关于如何生成此的任何想法?我可以使用视图生成组空间列表,但无法找到已启用功能的字段。 ...

5  批量保存节点与文件字段  ( Bulk saving nodes with a file field ) 
我正在为笨拙网站创建批量上载函数的进度。使用Flash我能够将文件上传到应该能够处理文件的特定URL。 我想做什么,不仅仅是上传文件,而是使用保存到已使用CCK设置的文件字段的文件创建特定类型的节点。由于这些是音频文件,因此文件字段处理文件是重要的,因此可以使用GetID3模块提供其他元数据。 我看了代码/ doc,...

3  如何处理博客标签在贡献主题中?  ( How to handle blog tags in a contrib theme ) 
在博客或博客的网站中,分类通常用于标签和类别。 在Drupal 6中,Node.TPL.php文件可以使用$分类系统,如果它们需要访问与当前节点相关联的UnRended分类链接数组。该变量通常是通过Control主题假设来包含帖子标记和或类别,并且相应地呈现。 在Drupal 7中,$分类学不再可用。 是什么选择...

11  hook_preprocess_page():如何讲述视图页面?  ( Hook preprocess page how to tell a views page ) 
im写一个需要在视图页面中插入一些javascript和css文件的自定义模块。 im使用hook_preprocess_page,但我无法判断当前页面是否来自视图: function mymodule_preprocess_page(&vars) { var_dump($vars); //outpu...

5  Field API与自定义代码  ( Field api versus custom code ) 
如果我需要仅为用户配置文件添加自定义字段,它是否更好地创建使用字段API的模块,或者使用自己的代码以自定义URL显示自定义字段的模块,并保存数据在自己的数据库表中? 字段API无法实现决定哪些字段可对其用户可见的权限;是足以实现自定义代码的原因? ...




© 2021 it.wenda123.org All Rights Reserved. 问答之家 版权所有


Licensed under cc by-sa 3.0 with attribution required.