Summary: in this tutorial, you will learn how to use SQL CREATE TABLE statement to create new tables in a database.

Introducing to SQL CREATE TABLE statement

SQL CREATE TABLETable is a basic element of the database. Table is like a spreadsheet which contains columns and rows. Table is used to store data e.g., customers, vendors, products…etc.

To create a new table you use SQL CREATE TABLE statement. The following illustrates the common syntax of the SQL CREATE TABLE statement:

Let’s examine the statement in greater detail:

  • Table name: it is recommended that the name of table should be as meaningful as possible. You should use plural form of a noun to name a table, for example products, orders, vendors...etc.
  • Column name: like table name, you should use meaning column name. If the column name is more long, you can use abbreviation such as ID for identity, No for number…etc.
  • Column data type: you should choose the appropriate data type for each column in a table. The most common data types are text (VARCHAR, NVARCHAR), numeric (SMALLINT, INT, BIGINT), DATE, TIME, DATETIME, BLOB…etc. Please refer the specific user manual of the database system you are working it to find the supporting data types.
  • Size of column: you have to specify the maximum length of data for each column. For example, if you store product name, try to imagine the maximum length that a product may contain.
  • Constraint:  You can define PRIMARY KEY, FOREIGN KEY, UNIQUE, NOT NULL or CHECK constraint with CONSTRAINT keyword. The CONSTRAINT keyword is optional.


We are going to create a new table named Projects to store project data. The following is the statement to create the Projects table.

In the projects table:

  • PorjectID: is the primary key defined by the PRIMARY KEY constraint. It is a NOT NULL and auto-increment column.
  • Name: the name of the project with VARCHAR data type with 255 characters long. It is a NOT NULL column.
  • Description: the description of the project with VARCHAR data type with 4000 characters long. It is a NULL-able column.
  • BeginDate and EndDate: is to specify the project’s period. They have the same DATE data type. The BeginDate is a NOT NULL column, while the EndDate  is NULL-able column.

In this tutorial, we’ve shown you how to use SQL CREATE TABLE statement to create new tables in the database.