oliverdavies.uk/source/_posts/add-taxonomy-term-multiple-nodes-using-sql.md

80 lines
3.2 KiB
Markdown
Raw Normal View History

2015-03-16 21:18:03 +00:00
---
title: Add a Taxonomy Term to Multiple Nodes Using SQL
2020-03-08 14:32:13 +00:00
date: 2010-07-07
2018-12-31 12:13:05 +00:00
excerpt: How to add a new taxonomy term to multiple nodes in Drupal using SQL.
2015-03-16 21:18:03 +00:00
tags:
2015-06-14 02:27:41 +00:00
- taxonomy
- drupal-planet
- drupal-6
- sql
- sequal-pro
- database
2015-03-16 21:18:03 +00:00
---
In preparation for my Blog posts being added to
[Drupal Planet](http://drupal.org/planet), I needed to create a new Taxonomy
term (or, in this case, tag) called 'Drupal Planet', and assign it to new
content to imported into their aggregator. After taking a quick look though my
previous posts, I decided that 14 of my previous posts were relevant, and
thought that it would be useful to also assign these the 'Drupal Planet' tag.
2015-03-16 21:18:03 +00:00
I didn't want to manually open each post and add the new tag, so I decided to
make the changes myself directly into the database using SQL, and as a follow-up
to a previous post -
[Quickly Change the Content Type of Multiple Nodes using SQL](/blog/change-content-type-multiple-nodes-using-sql/).
2015-03-16 21:18:03 +00:00
**Again, before changing any values within the database, ensure that you have an
up-to-date backup which you can restore if you encounter a problem!**
The first thing I did was create the 'Drupal Planet' term in my Tags vocabulary.
I decided to do this via the administration area of my site, and not via the
database. Then, using [Sequel Pro](http://www.sequelpro.com), I ran the
following SQL query to give me a list of Blog posts on my site - showing just
their titles and nid values.
2015-03-16 21:18:03 +00:00
2017-03-16 08:09:52 +00:00
```language-sql
2015-03-16 21:18:03 +00:00
SELECT title, nid FROM node WHERE TYPE = 'blog' ORDER BY title ASC;
2017-03-16 08:09:52 +00:00
```
2015-03-16 21:18:03 +00:00
I made a note of the nid's of the returned nodes, and kept them for later. I
then ran a similar query against the term_data table. This returned a list of
Taxonomy terms - showing the term's name, and it's unique tid value.
2015-03-16 21:18:03 +00:00
2017-03-16 08:09:52 +00:00
```language-sql
2015-05-03 17:55:38 +00:00
SELECT NAME, tid FROM term_data ORDER BY NAME ASC;
2017-03-16 08:09:52 +00:00
```
2015-03-16 21:18:03 +00:00
The term that I was interested in, Drupal Planet, had the tid of 84. To confirm
that no nodes were already assigned a taxonomy term with this tid, I ran another
query against the database. I'm using aliases within this query to link the
node, term_node and term_data tables. For more information on SQL aliases, take
a look at <http://w3schools.com/sql/sql_alias.asp>.
2015-03-16 21:18:03 +00:00
2017-03-16 08:09:52 +00:00
```language-sql
2015-05-03 17:55:38 +00:00
SELECT * FROM node n, term_data td, term_node tn WHERE td.tid = 84 AND n.nid = tn.nid AND tn.tid = td.tid;
2017-03-16 08:09:52 +00:00
```
2015-03-16 21:18:03 +00:00
As expected, it returned no rows.
The table that links node and term_data is called term_node, and is made up of
the nid and vid columns from the node table, as well as the tid column from the
term_data table. Is it is here that the additional rows would need to be
entered.
2015-03-16 21:18:03 +00:00
To confirm everything, I ran a simple query against an old post. I know that the
only taxonomy term associated with this post is 'Personal', which has a tid
value of 44.
2015-03-16 21:18:03 +00:00
2017-03-16 08:09:52 +00:00
```language-sql
2015-03-16 21:18:03 +00:00
SELECT nid, tid FROM term_node WHERE nid = 216;
2017-03-16 08:09:52 +00:00
```
2015-03-16 21:18:03 +00:00
Once the query had confirmed the correct tid value, I began to write the SQL
Insert statement that would be needed to add the new term to the required nodes.
The nid and vid values were the same on each node, and the value of my taxonomy
term would need to be 84.
2015-03-16 21:18:03 +00:00
Once this had completed with no errors, I returned to the administration area of
my Drupal site to confirm whether or not the nodes had been assigned the new
term.