Change Post Author in Ghost
When I moved this website from WordPress to Ghost earlier this year, I used their tool to import the posts in.
What it did, it created a 2nd user and associated the posts with that user while keeping the Ghost author (The main one that I would use) as a separate user. I didn't want this, so I decided to tinker with the SQLite database and change that.
Note: If you decide to follow my instructions, I am not responsible for any data loss or breakages to your site, ok? Good! :)
Just for a bit of context, I am using Ghost on Docker via Plesk, (click here for instructions on how to set that up).
To get into the terminal for your docker instance, rundocker ps
first and get the name of your docker container and then rundocker exec -t -i container_name bash
(replacingcontainer_name
with your own)
You will need to ensure that you have sqlite3
installed. On Debian/Ubuntu, you can do this by running apt update && apt install -y sqlite3
.
- BACK UP YOUR DATABASE. This should be obvious. Back up your databases before messing with it.
* Navigate to/var/lib/ghost/content/data
and runcp ghost.db ghostdb-backup2021-10-11
- While in
/var/lib/ghost/content/data
runsqlite3 ghost.db
- You will need to first find out the
author_id
of your users, to do this, run the commandSELECT id, name, slug FROM users;
This will return the following:
1|Padraig Fahy|padraig
8df7s89f7sd98f7sd|Ghost|ghost
7vc89x675x6c78x9c|Padraig Fahy|padraig-2
(Note: The id's are different for every instance and are randomised here)
From this, you might be able to determine which user is your WordPress user. But to be sure, go and view one of the posts that you would have created on the site and click on the link to the author, whether that would be a 'See more from this author' or similar link.
Then check the URL in the address bar to see what the 'slug' is. For me, all my WordPress posts where imported as 'padraig-2'
So the ID for 'padraig-2' would be 7vc89x675x6c78x9c
and now we want to change that to 1
so that it is the Ghost user 'padraig'
UPDATE posts SET author_id = REPLACE(author_id,'7vc89x675x6c78x9c','1');
- Press enter. Then run:
UPDATE posts_authors SET author_id = REPLACE(author_id,'7vc89x675x6c78x9c','1');
- And press enter again.
This will update the posts themselves to be the correct user and then update the 'authors' page to point it to the correct user.
When you try to go to the WordPress author page, it should return '0 Results'
You can verify your work by going to your proper author page https://padraig.blog/author/padraig/ and seeing your posts.
Repeat the process for the different authors if you have them.
Exit sqlite3 by running .quit
and pressing enter.