Codex

Interested in functions, hooks, classes, or methods? Check out the new WordPress Code Reference!

WordPress Taxonomy

WordPress 2.3 first introduced the current taxonomy schema. Any plugin that queries against the old WordPress 2.2 table structure will break horribly; plugins that use the category API should be fine.

This new schema replaced the categories, post2cat, and link2cat tables with three new tables that are much more flexible.

  1. wp_terms
  2. wp_term_taxonomy
  3. wp_term_relationships

wp_terms

The first table is the terms table. It holds the basic information about single terms.

 term_id bigint(20) unsigned NOT NULL auto_increment,
 name varchar(200) NOT NULL default '',
 slug varchar(200) NOT NULL default '',
 term_group bigint(10) NOT NULL default 0,
 PRIMARY KEY  (term_id),
 UNIQUE KEY slug (slug),
 KEY name (name)
  • term_id is a unique ID for the term.
  • name is simply the name of the term.
  • slug is unique and is the name reduced to a URL friendly form.
  • term_group is a means of grouping together similar terms.

wp_term_taxonomy

A term is not a category or tag on its own. It must be given context via the term_taxonomy table.

 term_taxonomy_id bigint(20) unsigned NOT NULL auto_increment,
 term_id bigint(20) unsigned NOT NULL default 0,
 taxonomy varchar(32) NOT NULL default '',
 description longtext NOT NULL,
 parent bigint(20) unsigned NOT NULL default 0,
 count bigint(20) NOT NULL default 0,
 PRIMARY KEY  (term_taxonomy_id),
 UNIQUE KEY term_id_taxonomy (term_id,taxonomy),
 KEY taxonomy (taxonomy)

The term_taxonomy table places a term within a taxonomy. This is what makes a term a category, a tag or part of a custom taxonomy (or in a combination of taxonomies).

  • term_id is the ID of a term in the terms table.
  • taxonomy designates the taxonomy in which the term resides. The default taxonomies are category, link_category, and post_tag.
  • term_taxonomy_id is a unique ID for the term+taxonomy pair.

The rest of the fields provide information about the term in the context of the taxonomy.

  • The parent field keeps track of hierarchical relationships between terms in the taxonomy.
  • description provides a taxonomy specific description of the term.
  • count tracks how many objects are associated with the term+taxonomy pair. For example, given a term of the category taxonomy, count tracks how many posts are in that specific category.

wp_term_relationships

The final table, term_relationships, relates objects such as posts or links to a term_taxonomy_id from the term_taxonomy table.

 object_id bigint(20) unsigned NOT NULL default 0,
 term_taxonomy_id bigint(20) unsigned NOT NULL default 0,
 term_order int(11) NOT NULL default 0,
 PRIMARY KEY  (object_id,term_taxonomy_id),
 KEY term_taxonomy_id (term_taxonomy_id)
  • object_id is the ID of a post or link.
  • term_taxonomy_id is an ID from the term_taxonomy table designating a particular term+taxonomy pair.
  • term_order allows an ordering of terms for an object (see ticket #5857)