# learn-postgresql **Repository Path**: mirrors_dwyl/learn-postgresql ## Basic Information - **Project Name**: learn-postgresql - **Description**: 🐘 Learn how to use PostgreSQL and Structured Query Language (SQL) to store and query your relational data. 🔍 - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-08-08 - **Last Updated**: 2026-05-30 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README
4. Run `sudo mkdir -p /etc/paths.d && echo /Applications/Postgres.app/Contents/Versions/latest/bin | sudo tee /etc/paths.d/postgresapp`
(found [here](https://postgresapp.com/documentation/install.html)) to use `psql` in the terminal.
Close and open the terminal.
5. Postgres.app will by default create a role and database that matches your current macOS username. You can connect straight away by running `psql`.
6. You should then see something in your terminal that looks like this (with your macOS username in front of the prompt rather than 'postgres'):

7. You should now be all set up to start using PostgreSQL. For documentation on
command line tools etc see https://postgresapp.com/documentation/
#### Ubuntu
Digital Ocean have got a great article on [getting started with postgres]( https://www.digitalocean.com/community/tutorials/how-to-install-and-use-postgresql-on-ubuntu-16-04). A quick summary is below.
##### Installation
```
sudo apt-get update
sudo apt-get install postgresql postgresql-contrib
```
By default the only role created is the default 'postgres', so PostgreSQL will only respond to connections from an Ubuntu user called 'postgres'. We need to pretend to be that user and create a role matching our actual Ubuntu username:
```
sudo -u postgres createuser --interactive
```
This command means 'run the command `createuser --interactive` as the user called "postgres"'.
When asked for the name of the role enter your Ubuntu username. If you're not sure, open a new Terminal tab and run `whoami`.
When asked if you want to make the role a superuser, type 'y'.
We now need to create the database matching the role name, as PostgreSQL expects this. Run:
```
sudo -u postgres createdb [your user name]
```
You can now connect to PostgreSQL by running `psql`.
### Create your first PostgreSQL database
1. To start PostgreSQL, type this command into the terminal:
`psql`
2. Next type this command into the PostgreSQL interface:
`CREATE DATABASE test;`
**NOTE:** Don't forget the semi-colon. If you do, useful error messages won't
show up.
3. To check that our database has been created, type `\l` into the psql prompt.
You should see something like this in your terminal:

### Create new users for your database
1. If you closed the PostgreSQL server, start it again with:
` psql`
2. To create a new user, type the following into the psql prompt:
```sql
CREATE USER testuser;
```
3. Check that your user has been created. Type `\du` into the prompt. You should
see something like this:

Users can be given certain permissions to access any given database you have
created.
4. Next we need to give our user permissions to access the test database we
created above. Enter the following command into the `psql` prompt:
```sql
GRANT ALL PRIVILEGES ON DATABASE test TO testuser;
```
### PostGIS - Spacial and Geographic objects for PostgreSQL
#### PostGIS Installation
If you've installed Postgres App as in the example above, you can easily
extend it to include PostGIS. Follow these steps to begin using PostGIS:
1. Ensure that you're logged in as a user OTHER THAN `postgres`. Follow the
steps above to enable your default user to be able to access the `psql` prompt.
(_[installation step 7](#installation)_)
2. Type the following into the `psql` prompt to add the extension:
`CREATE EXTENSION postgis;`
#### PostGIS Distance between two sets of coordinates
After you've extended PostgreSQL with PostGIS you can begin to use it. Type
the following command into the `psql` command line:
```sql
SELECT ST_Distance(gg1, gg2) As spheroid_dist
FROM (SELECT
ST_GeogFromText('SRID=4326;POINT(-72.1235 42.3521)') As gg1,
ST_GeogFromText('SRID=4326;POINT(-72.1235 43.1111)') As gg2
) As foo ;
```
This should return `spheroid_dist` along with a value in meters. The
example above returns: `84315.42034614` which is rougly 84.3km between the two
points.
### Commands
Once you are serving the database from your computer
- To change db
`\connect database_name;`
- To see the tables in the database
`\d;`
- To select (and show in terminal) all tables
`SELECT * FROM table_name`
- To make a table
`CREATE TABLE table_name (col_name1, col_name2)`
- To add a row
`INSERT INTO table_name ( col_name )
VALUES ( col_value)`
col_name only require if only some of the cols are being filled out
- To edit a column to a table
`ALTER TABLE table_name
ALTER COLUMN column_name SET DEFAULT expression`
- To add a column to a table
`ALTER TABLE table_name
ADD COLUMN column_name data_type`
- To find the number of instances where the word “Day” is present in the title of a table
`SELECT count(title) FROM table_name WHERE title LIKE '%Day%’;`
- To delete a row in a table
`DELETE FROM table_name
WHERE column_name = ‘hello';`
Postgresql follows the SQL convention of calling relations TABLES, attributes COLUMNs and tuples ROWS
**Transaction**
All or nothing, if something fails the other commands are rolled back like nothing happened
**Reference**
When a table is being created you can reference a column in another table to make sure any value which is added to that column exists in the referenced table.
```sql
CREATE TABLE cities (
name text NOT NULL,
postal_code varchar(9) CHECK (postal_code <> ''),
country_code char(2) REFERENCES countries,
PRIMARY KEY (country_code, postal_code)
);
```
`<>` means not equal
**Join reads**
You can join tables together when reading them,
**Inner Join**
Joins together two tables by specifying a column in each to join them by i.e.
```sql
SELECT cities.*, country_name
FROM cities INNER JOIN countries
ON cities.country_code = countries.country_code;
```
This will select all of the columns in both the countries
and cities tables the data, the rows are matched up by `country_code`.
**Grouping**
You can put rows into groups where the group is defined by a shared value in a particular column.
```sql
SELECT venue_id, count(*)
FROM events
GROUP BY venue_id;
```
This will group the rows together by the venue_id,
count is then performed on each of the groups.
### Learning Resources
+ Node-hero: https://blog.risingstack.com/node-js-database-tutorial
+ Pluralsight postgres getting started:
https://www.pluralsight.com/courses/postgresql-getting-started
+ Tech Republic Postgres setup:
https://www.techrepublic.com/article/diy-a-postgresql-database-server-setup-anyone-can-handle/
+ PostGIS installation: https://postgis.net/install
+ PostGIS docs: https://postgis.net/docs/manual-2.3
+ SQl Tutorials: https://www.scaler.com/topics/sql/
+ PostGIS ST_Distance: https://postgis.net/docs/ST_Distance.html
+ Foreign Key Constraints:
+ https://en.wikipedia.org/wiki/Foreign_key
+ https://www.postgresqltutorial.com/postgresql-tutorial/postgresql-foreign-key/
+ https://tableplus.io/blog/2018/08/postgresql-how-to-add-a-foreign-key.html
+ Graphical Interface (GUI) tools:
https://wiki.postgresql.org/wiki/Community_Guide_to_PostgreSQL_GUI_Tools