繁体   English   中英

查询以获取所有标签字段值并将所有值倒入字段

[英]Query to get a all tags field values and pour all value in field

更新:我需要获取标签字段的所有值!

我的查询:

$query = db_select('node', 'node');
$query->fields('tagsdata',array('name'));
$query->fields('node', array('nid'));

$query->leftJoin('field_data_field_tags', 'tags', 'tags.entity_id = node.nid');
$query->leftJoin('taxonomy_index', 'tagsindex', 'tagsindex.nid = tags.entity_id');
$query->leftJoin('taxonomy_term_data','tagsdata','tagsdata.tid = tags.field_tags_tid AND node.nid = tagsindex.nid');

$result = $query->execute();

    while( $record = $result->fetchAssoc() ) { 
        $items[] = $record;
    }

和我的代码:

    //SORT
   array_multisort(array_column($items, 'nid'), $items);
foreach ($items as $row) {

    $hash[$row[nid]] = $row;
}

$resultfinal = ($hash);
    // END SORT 
foreach($resultfinal as $finalarrays)
      {
         $tags=$finalarrays['name'];
         print_R ($tags);
      }

使用上面的代码只是返回标签的第一个和第一个值,我需要打印所有标签!

您可以使用GROUP_CONCAT mysql函数来获取所有由逗号引起的值:

$result = db_query("SELECT tags.entity_id as nid, GROUP_CONCAT(t.name) as tdata  FROM field_data_field_tags 
INNER JOIN taxonomy_term_data t ON t.tid = tags.field_tags_tid 
WHERE tags.entity_type = :type GROUP BY tags.entity_id", 
array(':type' => 'node'))->fetchAllKeyed();

注意:有时您需要连接的字符串太多,因此需要在以下之前增加限制:

db_query('SET SESSION group_concat_max_len=10000');
$result = db_query("SELECT tags.entity_id as nid, GROUP_CONCAT(t.name) as tdata  FROM field_data_field_tags 
INNER JOIN taxonomy_term_data t ON t.tid = tags.field_tags_tid 
WHERE tags.entity_type = :type GROUP BY tags.entity_id", 
array(':type' => 'node'))->fetchAllKeyed();

https://dev.mysql.com/doc/refman/5.7/en/group-by-functions.html#function_group-concat

foreach($result as $nid => $tags) {
  echo $nid . ' : '.$tags;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM