Install PostgreSQL Database on Ubuntu
1. Introduction
Document is based on:
- Ubuntu 14, 16, 18, 20
- PostGres 9.6, 10, 11, 12
The post can be applied to Unbuntu with the version of 12, 14 or 16,...
You can find out other versions of PostGres here:
data:image/s3,"s3://crabby-images/6e2ba/6e2ba35aaebe884f6e21f1d81523d6cece25782f" alt=""
2. Install PostGres
First, check which version of Ubuntu you are using. Pay attention to UBUNTU_CODENAME, it's important to you now.
cat /etc/*release
data:image/s3,"s3://crabby-images/9147f/9147fdc7a3f45f3ade0099bddbac20c413ade1f1" alt=""
Version | Code name | Release date | End of Life date |
Ubuntu 20.4 LST | focal | August 13, 2020 | |
Ubuntu 18.04.1 LTS | bionic | July 26, 2018 | April 2023 |
Ubuntu 18.04 LTS | bionic | April 26, 2018 | April 2023 |
Ubuntu 16.04.4 LTS | xenial | March 1, 2018 | April 2021 |
Ubuntu 16.04.3 LTS | xenial | August 3, 2017 | April 2021 |
Ubuntu 16.04.2 LTS | xenial | February 16, 2017 | April 2021 |
Ubuntu 16.04.1 LTS | xenial | July 21, 2016 | April 2021 |
Ubuntu 16.04 LTS | xenial | April 21, 2016 | April 2021 |
Ubuntu 14.04.5 LTS | trusty | August 4, 2016 | April 2019 |
Ubuntu 14.04.4 LTS | trusty | February 18, 2016 | HWE August 2016 |
Ubuntu 14.04.3 LTS | trusty | August 6, 2015 | HWE August 2016 |
Ubuntu 14.04.2 LTS | trusty | February 20, 2015 | HWE August 2016 |
Ubuntu 14.04.1 LTS | trusty | July 24, 2014 | April 2019 |
Ubuntu 14.04 LTS | trusty | April 17, 2014 | April 2019 |
Installing:
Execute the following commands on the Terminal, note: Replace {UBUNTU_CODENAME} by your UBUNTU_CODENAME.
sudo add-apt-repository "deb https://apt.postgresql.org/pub/repos/apt/ {UBUNTU_CODENAME}-pgdg main"
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
sudo apt-get update
sudo apt-get install postgresql-12
Ubuntu 20:
sudo add-apt-repository "deb https://apt.postgresql.org/pub/repos/apt/ focal-pgdg main"
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
sudo apt-get update
sudo apt-get install postgresql-12
Ubuntu 18:
sudo add-apt-repository "deb https://apt.postgresql.org/pub/repos/apt/ bionic-pgdg main"
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
sudo apt-get update
sudo apt-get install postgresql-12
Ubuntu 16:
sudo add-apt-repository "deb https://apt.postgresql.org/pub/repos/apt/ xenial-pgdg main"
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
sudo apt-get update
sudo apt-get install postgresql-9.6
If you receive an error when installing, please see the appendix at the end of this post:E: The method driver /usr/lib/apt/methods/https could not be found. N: Is the package apt-transport-https installed? E: Failed to fetch https://apt.postgresql.org/pub/repos/apt/dists/xenial-pgdg/InRelease E: Some index files failed to download. They have been ignored, or old ones used instead.
Start postgres:
sudo service postgresql start
3. Set up a password for the user postgres
Firstly, you need to log in PostGres (With root right of Ubuntu).
sudo -u postgres psql
data:image/s3,"s3://crabby-images/5da1c/5da1c548797ad62559369a1d48a2c82936f963bf" alt=""
You have logged in PostGres successully:
data:image/s3,"s3://crabby-images/61a04/61a0499680ec4bf2013f229f110ded459b96b943" alt=""
In PostGres, "postgres" is root user, you can set up new password for this user:
ALTER USER postgres PASSWORD 'newpassword';
data:image/s3,"s3://crabby-images/bf46f/bf46f54039ea0d752bc94b21484a8dfba1ed8a13" alt=""
After changing password successfully, you can exit PostGres with the command "\q".
data:image/s3,"s3://crabby-images/a5564/a556445be2e8e03540440a72e1e7195850e0c560" alt=""
After the password of the user "postgres" has been set up, you can log in to the Postgres through the command:
psql -U postgres -h localhost
data:image/s3,"s3://crabby-images/3dfe0/3dfe00b34b2ee9d9de403e1fab47ea71282aa205" alt=""
Enter the password that you set up above
data:image/s3,"s3://crabby-images/4cd00/4cd00a0c8234176f6aacd4d8f83dd4c420701a42" alt=""
4. Using PostGreSQL
Make sure that you log in Postgres with user "postgres".
data:image/s3,"s3://crabby-images/1210e/1210ebe48b5e1685ba324cc2e8f775aae1507e30" alt=""
data:image/s3,"s3://crabby-images/2f494/2f4949cfb9d7cc05240a5e8949fbd49827ce4480" alt=""
Run 3 following commands to create user, database, and grant all the privileges of using the database to the use that is newly created.
CREATE USER myuser with PASSWORD '123';
CREATE DATABASE mydb;
GRANT ALL PRIVILEGES ON DATABASE mydb TO myuser;
data:image/s3,"s3://crabby-images/4cdbd/4cdbdea967f61001d4512bd8a9f0299101d31a36" alt=""
data:image/s3,"s3://crabby-images/f27df/f27df5f089cdb6f2793ca1d3d4facf6f795644d5" alt=""
data:image/s3,"s3://crabby-images/f0faa/f0faae7ce422b6f378651a2c10dc450beb79ff9c" alt=""
data:image/s3,"s3://crabby-images/d4edd/d4eddac49230e8c58c3ae1ccdf9120abff5ac7e1" alt=""
See in pgAdmin3:
data:image/s3,"s3://crabby-images/6323b/6323bbc59bd93335816fa9088b0845ce2231ecd1" alt=""
Connect to "mydb" database with user "myuser":
Exit PostGres:
data:image/s3,"s3://crabby-images/42549/42549041687c89e4c15f2f2d5ac815888b3dcf06" alt=""
Logon "mydb" database with user "myuser":
psql -U myuser -h localhost -d mydb
data:image/s3,"s3://crabby-images/c0343/c0343badd593c6358da70260e7b075d62145f305" alt=""
Now you have connected to database "mydb":
data:image/s3,"s3://crabby-images/b41de/b41de77361421b12fa52333315ac0ffc39389db8" alt=""
Create table:
-- Create table Account
Create table Account (User_Name varchar(30), Full_Name varchar(64) ) ;
-- Insert 2 row to Account.
Insert into Account(user_name, full_name) values ('gates', 'Bill Gate');
Insert into Account(user_name, full_name) values ('edison', 'Thomas Edison');
-- Query
Select * from Account;
data:image/s3,"s3://crabby-images/b9b6c/b9b6cfa3ee7e0e21caf796275ab21e3811b9520b" alt=""
data:image/s3,"s3://crabby-images/60e6a/60e6a2694f466f08bf8086a58edcf39fe7fd18c2" alt=""
data:image/s3,"s3://crabby-images/95f4b/95f4ba4805adfe30f54022f23e2d621733818c68" alt=""
data:image/s3,"s3://crabby-images/bc074/bc074c905277bcdc080ea099a8890bcc1aea9b13" alt=""
data:image/s3,"s3://crabby-images/599c6/599c66d8703a44dac418f2cb40d4f7167750da72" alt=""
See on pgAdmin3:
data:image/s3,"s3://crabby-images/b3cc4/b3cc4f03f8b40026eaee59a42b1c21e7caee1d35" alt=""
5. Install pgAdmin
pgAdmin is a software, visual tool that helps you work with the Postgres database, you can install it according to the instruction below:
data:image/s3,"s3://crabby-images/46a35/46a35428d7b2a635164a38e69008eb32af46aaf0" alt=""
6. Appendix: Fix Error
If you receive an error message:
E: The method driver /usr/lib/apt/methods/https could not be found.
N: Is the package apt-transport-https installed?
E: Failed to fetch https://apt.postgresql.org/pub/repos/apt/dists/xenial-pgdg/InRelease
E: Some index files failed to download. They have been ignored, or old ones used instead.
data:image/s3,"s3://crabby-images/1599b/1599b560f083cbf93c1aadec5695b4a9bee480c3" alt=""
Run command:
sudo apt-get install apt-transport-https
data:image/s3,"s3://crabby-images/650da/650da589e77aedec480618d47e8f4d39f06a82ef" alt=""
data:image/s3,"s3://crabby-images/efadf/efadfbe215ad744ae16ce0e6094a0295760e4589" alt=""