I’ve created a custom post type called 'publications'
and a custom taxonomy called 'topics'
. I’m also using the standard taxonomy of 'category'
.
My Custom Query makes sure that it fetches ALL 'publications'
that are in the correct 'category'
but I’d like it to also ORDER BY
the additional 'topics'
taxonomy.
This custom query does fetch all the correct 'publications'
but I’m having no luck with the ORDER BY
section:
$querystr = "
SELECT *
FROM $wpdb->posts
LEFT JOIN $wpdb->term_relationships ON ($wpdb->posts.ID = $wpdb->term_relationships.object_id)
LEFT JOIN $wpdb->term_taxonomy ON ($wpdb->term_relationships.term_taxonomy_id = $wpdb->term_taxonomy.term_taxonomy_id)
LEFT JOIN $wpdb->terms ON ($wpdb->term_taxonomy.term_id = $wpdb->terms.term_id)
WHERE $wpdb->posts.post_type = 'publications'
AND $wpdb->terms.slug = %s
AND $wpdb->term_taxonomy.taxonomy = 'category'
ORDER BY $wpdb->term_taxonomy.taxonomy = 'topics' DESC
";
$pageposts = $wpdb->get_results($wpdb->prepare($querystr, array($parent_post_slug)));
The $parent_post_slug
is the 'category'
name. And it’s fetching all the correct Posts. Just how would I order them by the taxonomy called 'topics'
?
An example of the order I’d like:
Category Name = Fiction (This page is just showing the fiction publications)
Publication 1 = has custom taxonomy topic of Alligators
Publication 2 = has custom taxonomy topic of Alligators
Publication 3 = has custom taxonomy topic of Antelopes
Publication 4 = has custom taxonomy topic of Buffalos
Publication 5 = has custom taxonomy topic of Buffalos
Any idea of what I should be using in the ORDER BY
line to get this to work?
Just looking at the term_taxonomy table, you are selecting everything correctly, but the last part:
from the post_type of publications, the terms slug of %s, and has the taxonomy of categories, but you are never selecting the taxonomy topics. If you look at the table, you have one column reading taxonomy. In this column, you can either have category or topics. This is an example of two rows (plus the header):
(I put it in tabular notation to express it easier)
try throwing the topics into the select query, then sorting by it:
Finally, I have managed to make this work. I’ve found the holy grail of ordering custom post types by a custom taxonomy, with pagination. The code isn’t pretty but it works.
My method was to forget about SQL queries and to just select ALL the custom posts that matched the correct Category and the correct Custom Post Type (my Category is taken from the current page slug, i.e. foo.com/bar ‘bar’ is my category).
Then create a custom array from the result containing each Post ID, Custom Taxonomy (‘topics’) Term and Custom Taxonomy Slug.
Then SORT this array. Then SLICE this array depending on what page you’re on, i.e. Page 1, Page 2, Page 3. We just selecting the Publications to show on that page. And then loop the results.
I manage to ‘group’ my results into these ‘topics’ by just checking if we printed out the same Custom Taxonomy Term on the previous post.
All the pagination is done using the $current_paged_num code near the top and the paginate links code at the bottom.
Yes, my code is ugly and probably a huge resource hog but it works. And so I’m sharing it here in case I can help anybody else out. If you think you can tidy or prettify this code then please show us here.