038 SQL INSERT INTO SELECT
The webpage explains the SQL INSERT INTO SELECT statement, which is used to copy data from one table and insert it into another table. Key points include:
- Purpose: To transfer rows from a source table into a target table. Data types must match between the two tables. Existing records in the target table are not affected.
- Syntax:
- To copy all columns:
 INSERT INTO table2 SELECT * FROM table1 WHERE condition;- To copy selected columns:
 INSERT INTO table2 (column1, column2, ...) SELECT column1, column2, ... FROM table1 WHERE condition;
- Examples: The page provides practical SQL code snippets, such as copying supplier information into a customers table, with the option to filter which records are copied, e.g., only those from a specific country.
- Demo Tables: Uses the Northwind sample database’s Customers and Suppliers tables for demonstration.
An exercise is included to reinforce that the primary purpose of INSERT INTO SELECT is to copy data from one table to another, not to delete, test existence, or combine like a join.
This resource is optimized for learning, with interactive examples, explanations, and reference links.
SQL INSERT INTO SELECT Statement
The SQL INSERT INTO SELECT Statement
The INSERT INTO SELECT statement copies data from one table and inserts it into another table.
The INSERT INTO SELECT statement requires that the data types in source and target tables match.
Note: The existing records in the target table are unaffected.
INSERT INTO SELECT Syntax
Copy all columns from one table to another table:
INSERT INTO table2
SELECT * FROM table1
WHERE condition;
Copy only some columns from one table into another table:
INSERT INTO table2 (column1, column2, column3, ...)
SELECT column1, column2, column3, ...
FROM table1
WHERE condition;
Demo Database
In this tutorial we will use the well-known Northwind sample database.
Below is a selection from the "Customers" table:
| CustomerID | CustomerName | ContactName | Address | City | PostalCode | Country | 
|---|---|---|---|---|---|---|
| 1 | Alfreds Futterkiste | Maria Anders | Obere Str. 57 | Berlin | 12209 | Germany | 
| 2 | Ana Trujillo Emparedados y helados | Ana Trujillo | Avda. de la Constitución 2222 | México D.F. | 05021 | Mexico | 
| 3 | Antonio Moreno Taquería | Antonio Moreno | Mataderos 2312 | México D.F. | 05023 | Mexico | 
And a selection from the "Suppliers" table:
| SupplierID | SupplierName | ContactName | Address | City | Postal Code | Country | 
|---|---|---|---|---|---|---|
| 1 | Exotic Liquid | Charlotte Cooper | 49 Gilbert St. | Londona | EC1 4SD | UK | 
| 2 | New Orleans Cajun Delights | Shelley Burke | P.O. Box 78934 | New Orleans | 70117 | USA | 
| 3 | Grandma Kelly's Homestead | Regina Murphy | 707 Oxford Rd. | Ann Arbor | 48104 | USA | 
SQL INSERT INTO SELECT Examples
Copy "Suppliers" into "Customers" (the columns that are not filled with data, will contain NULL):
INSERT INTO Customers (CustomerName, City, Country)  
SELECT SupplierName, City, Country FROM Suppliers;
Copy "Suppliers" into "Customers" (fill all columns):
INSERT INTO Customers (CustomerName, ContactName, Address, City, PostalCode, Country)  
SELECT SupplierName, ContactName, Address, City, PostalCode, Country FROM Suppliers;
Copy only the German suppliers into "Customers":
INSERT INTO Customers (CustomerName, City, Country)  
SELECT SupplierName, City, Country FROM Suppliers  
WHERE Country='Germany';