Add Bookmarks to WordPress via the Database

Wednesday, 08/04/2009 ≅17:59 ©cat

I want to add links to the slackpackages I've built. The first step to doing properly is to get the links into the WordPress database. Given WP's fantastically crappy admin UI, this would take at least two hours if I did them by hand, and I would undoubtedly introduce numerous errors. I decided to write a script that would create SQL that I could import via phpmyadmin.

First, I created a list of the files I wanted to link to:
(they are already uploaded to my hosted environment)
ssh webhost
cd /path/to/content
ls *CAT* > slack.list

Then I brought the file to my local environment to work on it:
rsync -brave ssh user@host:/path/to/content/slack.list .

I knew I wanted the links to be named identically to their files, so I created a new file with two identical columns:
while read line; do
echo -e "${line}\t${line}" >> links.info
done < slack.list

I could have done this in the original file, but I wanted to keep the original around in case I borked my working copy.

I opened up the file in vi and created URLs out of the first column:
:% s/^/http:\/\/servername.domain.tld\/PATH\/TO\/FILES/

I researched in /wp-admin and on the net and discovered what other information I needed to add the bookmarks. James Wallace was especially helpful. I created a category for all these links to go in, and found the category's id number in wpdb.terms.term_id WHERE name=[name of category]. I found the category to item key in wpdb.term_taxonomy.term_taxonomy_id WHERE term_id = [the term_id we already found]. The most difficult part was trying to determine how wpdb.term_relationships.object_id is determined for each record. Looking at the table, it's clearly an index key but it's not autoincremented, so it must be coming from somewhere else. The code in /wp-admin that deals with these updates, while grammatically excellent and extensible, is not exactly clear.

I went back to links.info and added this information to each line:
:% s/$/\t[term_id]\t[term_taxonomy_id]

Of course, you'll want to replace the brackets and what's between them with the numeric values you got from your database. Also, you don't have to add one category at a time. I specifically designed this script so that a list of links destined for inclusion in various categories can all be added at once.

I deleted the links via the admin interface, and removed all trace of them from wpdb.term_relationships. I now had a pristine condition from which the autoincrementing fields could start counting automagically, and would be able to create my own relationships in the taxonomy mess without stomping on anything else. The script could just as easily append to existing data by removing the DROP/CREATE statements.

My SQL isn't especially sharp, so I swiped the DROP/CREATE statements and "INSERT wpdb.links" prototype from a backup generated by phpMyAdmin. The DROP/CREATE lent itself to a HERE statement, of course. I setup a loop that reads each column from my input file, and generates SQL for each record. First, we insert the link into wpdb.links. Then we create the relationship with the category in wpdb.term_relationships. Finally, the third statement updates the link count in wpdb.term_taxonomy.

I ran my script, and it generated statements for 41 records in 0.115 seconds and used the 'Import' feature of phpMyAdmin to run the SQL the script generated. I was able to add 41 records into the database 0.0018 seconds.

Note that I did all my testing in the dev environment on my laptop. DO NOT ATTEMPT DATABASE MANIPULATION IN A PRODUCTION ENVIRONMENT.

However, it took me quite a while to get the script working properly, especially researching the ABSOLUTE MESS that is $object_id, $term_id and $term_taxonomy_id. Therefore, I want to post this so that other people who want to import large datasets of links into WordPress can have a much easier time of it.

You can copy the script here.



Looking for slackware packages? I have a few dozen packages I've built, including multimedia libraries, gimp 2.6, afterstep 2.2.8 etc. Build scripts are included so you can tweak them for your system.

3 thoughts provoked

 On Wednesday, 08/04/2009 ≅ 17:59 ©Add Bookmarks to WordPress via the Database spoke thusly: 

[...] more:  Add Bookmarks to WordPress via the Database Posted in wordpress | Tags: detected, doing-properly, first-step, hosted-at-wordpress, [...]



 On Wednesday, 08/04/2009 ≅ 17:59 ©New features at BrainyCat World Domination HQ @ The Adventures of Brainy Cat spoke thusly: 

[...] to a set of nearly identical albums. I looked at the database, thinking I could cheat a little like I did with WordPress, but there’s 63 tables in that database! Forgive me for a moment of laziness, and deciding to just [...]



 On Wednesday, 08/04/2009 ≅ 17:59 ©Tyncserv spoke thusly: 

72]ВХОД на ПОРНО САЙТ

46] ВХОД

http://pipiskun.la nd.ru/xr3/32.jpg http://pipiskun.land.ru/xr3/30.jpg
http://pipiskun.land.ru/xr3/23.jpg http://pipiskun.land.ru/xr3/9.jpg
http://pipiskun.land.ru/xr3/51.jpg http://pipiskun.land.ru/xr3/68.jpg
http://pipiskun.land.ru/xr3/61.jpg http://pipiskun.land.ru/xr3/17.jpg

46] ПОРНО

72]САМОЕ СВЕЖЕЕ ПОРЕВО

72]эротика видио скачать
72]порнуха лезбиянки ролик загрузить
72]xxx фильм загрузить сайт

видео порно ролик посмотреть порно-сайт
видео эротика посмотреть
порно фильм скачать
видео порно ролик скачать
онлайн sex dvd загрузить

порно секс мужчины
мужчин порно viewforum php f
порно красивые мужчины
смотреть фото девушек
смотреть фото девушек
смотреть фото девушек
голая анна плетнева
голая анна седокова
голая анна
фото молоденьких девушек blogs
смотреть порно молоденькие
фото молоденьких девушек blogs
Arrayдевушки обнажаются
картины обнаженных девушек
картины обнаженных девушек
порно жены
порно чужие жены
порно чужие жены
оргиями blogs
оргии фотографии
фото сумасшедших оргий blogs
смотреть порно онлайн
онлайн порно школьников
онлайн порно школьников
посмотреть порно лесбиянок
порно лесбиянок
порно фото секс лесбиянок
сайт семейного порно
сайт семейного порно
сайт семейного порно
трах видео смотреть
трах видео bbs
трах видео смотреть
малолетний трах онлайн
трах школьницы онлайн
малолетний трах онлайн
секс девушки inurl comments asp
секс парень девушка minibb
секс девушки inurl comments asp
голые 18 девчонки
голые 18 девчонки
фотки голых девчонок
влад писька добавить
девченки письки
старые письки
секс видео ролики
секс видео ролики ipb
секс видео ролики ipb
скрытая камера порно фото
скрытая порно камера бесплатно
скрытая камера порно видео vbulletin
первый секс подростка
подростки фильм секс
первый подростковый секс
порно бабушки онлайн
www порно ру
www порно ру
www порно ру
порно мультфильм красная шапочка
порно мультфильмы скочать forum
порно мультфильм красная шапочка
порно видео мульт
мульт порно зарегистрированные пользователи
флеш порно мульты
посмотреть интернет порно видео
интернет магазин порно
интернет порно видео
порно мамаши толстые
порно мамаши
мамаши онлайн порно
скачать видео ролики лесбиянки blogs
лесбиянки ролики
лесбиянки ролики
порно сайты
порно сайты
порно сайты
видео ролик эротека порно
порно видео ролики бесплатно
посмотреть порно видео ролики
порно женщины
порно фото русских женщин
порно фото русских женщин
порно с анной семенович
порно с анной семенович
смотреть порно анны семенович
секс порно видео ролики онлайн
секс ролики смотреть ipb
бесплатно секс ролики
www порно ru
www порно онлайн
www порно видео
13 летние порно девочки
порно фотографий голых девочек
порно девочки
гей сайт красноярска
гей сайты
гей сайт красноярска
изящной создать топик
изящным board
изящный век
порно ролики маленькие девочки
порно фото малолетних девочек
порно фото девочек
бурный оргазм девушки
девушки испытывают оргазм
как сделать девушке оргазм
секси видео
секси видео
секс порно видео
порно фото анал анус
тугой анус порно viewforum php f
тугой анус порно viewforum php f
порно мульты онлайн
3d порно мульты
порно мульты онлайн
смотреть порно фильм школьница
смотреть порно фильм безплатно bb
смотреть порно фильм безплатно bb
смотреть порно со знаменитостями онлайн
порно со знаменитостями онлайн
смотреть порно со знаменитостями
порно фото архив
порно видео архив new thread
порно видео архив new thread
порно блондинка
порно фотографии блондинок
порно видео блондинки
скачать порно со звездами
скачать порно видео со звездами без регистрации
скачать порно со звездами

он-лайн порнуха видеоролик загрузить
порно посмотреть сайт
эротика скачать
онлайн nude film просмотр
он-лайн nude фильм посмотреть
видео эротика посмотреть
on-line porno dvd посмотреть портал
online порнуха скачать
xxx ролик загрузить сайт
он-лайн порнуха скачать
онлайн голая фильм посмотреть
он-лайн порнуха dvd просмотр
xxx ролик посмотреть
интернет голые двд скачать порно-сайт



Be Provoking: