SQL: Create a new table

A database is composed by one or more tables.

Creating a table in SQL is done using the CREATE TABLE command.

At creation time you need to specify the table columns names, and the type of data they are going to hold.

This is the syntax to create a people table with 2 columns, one an integer and the other a variable length string:

CREATE TABLE people (
  age INTEGER, 
  name TEXT
);

NOTE: each SQL query must end with a semicolon.

Write the query in the TablePlus SQL editor, select it with the mouse and then click “Run Current” to run the query:

Click the refresh button to see the new table on the left:

Now you can click the people table on the left and you’ll see its content, now empty:

and if you click the Structure switch at the bottom you’ll see the table structure as we defined it (and from here you can change it as well, if you want)

SQL defines several kinds of data.

The most important and the ones you’ll see more often are:

  • CHAR
  • TEXT
  • VARCHAR
  • DATE
  • TIME
  • DATETIME
  • TIMESTAMP

Numeric types include, among others:

  • INT 4 bytes
  • BIGINT 8 bytes
  • DECIMAL
  • FLOAT

They all hold numbers. What changes is the size that this number can be. The bigger the size in bytes, the more space will be needed in storage.

HOWEVER, and it’s very important, each individual SQL database (PostgreSQL, SQLite, MySQL, MariaDB…) has its set of types, each optimized for different needs.

In PostgreSQL for example we use TIMESTAMP in Postgres, but SQLite doesn’t have that type. So we can’t easily do a single SQL query on multiple databases (we have libraries to help us abstract this kind of implementation detail).

Lessons in this unit:

0: Introduction
1: Using TablePlus
2: Create a Postgres database
3: ▶︎ Create a new table
4: Add data to a table
5: Query data with SELECT
6: Delete data from the database
7: Update data with UPDATE
8: Null constraints
9: Unique and primary keys
10: Updating a table structure
11: Joins