Curriculum
In this tutorial, you will learn how to insert data into a table using the SQL INSERT statement.
SQL provides the INSERT statement that allows you to insert one or more rows into a table. The INSERT statement allows you to:
We will examine each function of the INSERT statement in the following sections.
To insert one row into a table, you use the following syntax of the INSERT statement.
INSERT INTO table1 (column1, column2,...)
VALUES
    (value1, value2,...);
There are some points that you should pay attention to when you insert a new row into a table:
It is not necessary to specify the columns if the sequence of values matches the order of the columns in the table. See the following INSERT statement that omits the column list in the INSERT INTO clause.
INSERT INTO table1
VALUES
    (value1, value2,...);
However, this is not considering as a good practice.
If you don’t specify a column and its value in the INSERT statement when you insert a new row, that column will take a default value specified in the table structure. The default value could be 0, a next integer value in a sequence, the current time, a NULL value, etc. See the following statement:
INSERT INTO (column1, column3)
VALUES
    (column1, column3);
In this syntax, the column2 will take a default value.
We will use the employees and dependents tables in the sample database to show you how to insert one row into the table.
In this syntax, the column2 will take a default value.
We will use the employees and dependents tables in the sample database to show you how to insert one row into the table.
INSERT INTO dependents (
    first_name,
    last_name,
    relationship,
    employee_id
)
VALUES
    (
        'Dustin',
        'Johnson',
        'Child',
        178
    );
We did not use the department_id column in the INSERT statement because the dependent_id column is an auto-increment column, therefore, the database system uses the next integer number as the default value when you insert a new row.
The employee_id column is a foreign key that links the dependents table to the  employees table. Before adding the new rows, the database system checks if the value 178 exists in the employee_id column of the  employees table to make sure that the foreign key constraint is not violated.
If the row is inserted successfully, the database system returned the number of the affected rows.
Affected rows: 1
You can check whether the row has been inserted successfully or not by using the following SELECT statement.
SELECT 
    *
FROM
    dependents
WHERE
    employee_id = 178;
To insert multiple rows using a single INSERT statement, you use the following construct:
INSERT INTO table1
VALUES
    (value1, value2,...),
    (value1, value2,...),
    (value1, value2,...),
    ...;
For example, to insert two rows into the dependents table, you use the following query.
INSERT INTO dependents (
    first_name,
    last_name,
    relationship,
    employee_id
)
VALUES
    (
        'Cameron',
        'Bell',
        'Child',
        192
    ),
    (
        'Michelle',
        'Bell',
        'Child',
        192
    );
The database system returns 2 rows affected. You can verify the result using the following statement.
SELECT 
    *
FROM
    dependents
WHERE
    employee_id = 192;
You can use the INSERT statement to query data from one or more tables and insert it into another table as follows:
INSERT INTO table1 (column1, column2) 
SELECT
    column1,
    column2
FROM
    table2
WHERE
    condition1;
In this syntax, you use a SELECT which is called a subselect instead of the  VALUES clause . The subselect can contain the joins so that you can combine data from multiple tables. When executing the statement, the database system evaluates the subselect first before inserting data.
Suppose, you have a table named dependents_archive that has the same structure as the dependents table. The following statement copies all rows from the dependents table to the dependents_archive table.
INSERT INTO dependents_archive 
SELECT
    *
FROM
    dependents;
You can verify the insert operation by using the following statement.
SELECT
    *
FROM
    dependents_archive;
Â