Support id=>parent in fields arg of get_terms. Returns array of parent ids keyed by the id of the child term.

git-svn-id: https://develop.svn.wordpress.org/trunk@12729 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Ryan Boren 2010-01-15 17:40:37 +00:00
parent b74bea8a2c
commit 85de154ee3

View File

@ -797,11 +797,11 @@ function &get_terms($taxonomies, $args = '') {
$selects = array(); $selects = array();
if ( 'all' == $fields ) if ( 'all' == $fields )
$selects = array('t.*', 'tt.*'); $selects = array('t.*', 'tt.*');
else if ( 'ids' == $fields ) else if ( 'ids' == $fields || 'id=>parent' == $fields )
$selects = array('t.term_id', 'tt.parent', 'tt.count'); $selects = array('t.term_id', 'tt.parent', 'tt.count');
else if ( 'names' == $fields ) else if ( 'names' == $fields )
$selects = array('t.term_id', 'tt.parent', 'tt.count', 't.name'); $selects = array('t.term_id', 'tt.parent', 'tt.count', 't.name');
$select_this = implode(', ', apply_filters( 'get_terms_fields', $selects, $args )); $select_this = implode(', ', apply_filters( 'get_terms_fields', $selects, $args ));
$query = "SELECT $select_this FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON t.term_id = tt.term_id WHERE tt.taxonomy IN ($in_taxonomies) $where ORDER BY $orderby $order $limit"; $query = "SELECT $select_this FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON t.term_id = tt.term_id WHERE tt.taxonomy IN ($in_taxonomies) $where ORDER BY $orderby $order $limit";
@ -844,7 +844,11 @@ function &get_terms($taxonomies, $args = '') {
reset ( $terms ); reset ( $terms );
$_terms = array(); $_terms = array();
if ( 'ids' == $fields ) { if ( 'id=>parent' == $fields ) {
while ( $term = array_shift($terms) )
$_terms[$term->term_id] = $term->parent;
$terms = $_terms;
} elseif ( 'ids' == $fields ) {
while ( $term = array_shift($terms) ) while ( $term = array_shift($terms) )
$_terms[] = $term->term_id; $_terms[] = $term->term_id;
$terms = $_terms; $terms = $_terms;
@ -2066,10 +2070,10 @@ function _get_term_hierarchy($taxonomy) {
return $children; return $children;
$children = array(); $children = array();
$terms = get_terms($taxonomy, array('get' => 'all', 'orderby' => 'id', 'fields' => 'ids')); $terms = get_terms($taxonomy, array('get' => 'all', 'orderby' => 'id', 'fields' => 'id=>parent'));
foreach ( $terms as $term ) { foreach ( $terms as $term_id => $parent ) {
if ( $term->parent > 0 ) if ( $parent > 0 )
$children[$term->parent][] = $term->term_id; $children[$parent][] = $term_id;
} }
set_transient("{$taxonomy}_children", $children); set_transient("{$taxonomy}_children", $children);