Tell the server that we want to add new rows (records) to a table
If we want to bulk insert data, we can reference it from another table
INSERT INTO "<schema_name>"."<table_name>" (<field_name1>, <field_name2>)
SELECT <value1>, <value2>
FROM <table> | <view>;
Product Offers
We have received a bulk of new planned offers in a CSV file
- CSV = Comma Separated Values
- It's a bit like a table where:
- Columns are separated by commas
- Rows are separated by new lines
Loading this into a staging table
- When we receive data from an external source like this it is a good idea not to put it into our production database immediately
- It is best to create a 'staging' table so we can triage it before we bulk insert
- Let's call our staging table
stage_Product_Offers
- It will be the same as
Product_Offers
except:- We're including the word
stage_
in the table name - We're not including the
offer_id
because this will be generated automatically
- We're including the word
CREATE TABLE "sequel-mart-schema"."stage_Product_Offers" (
offer_name VARCHAR(50) NOT NULL,
product_id INT NOT NULL DEFAULT 0,
offer_discount_percentage NUMERIC(4,2),
offer_start_date DATE,
offer_end_date DATE
);
Make sure the schema is included in the name
Import the CSV data to this table
Because we are using a Docker image we can't just pull the data straight from our hard-drive.
-
Right-click on the
stage_Product_Offers
table (screenshot 3) -
Click 'Import/Export Data...' and fill the form out:
Options Tab
- Import/Export = Import
- Filename
- Click on the file icon on the right
- Click the up-arrow icon on the left of the new pop-up until you get to the root folder ('/') (screenshot 5)
- You should see a long list of folders
- Select the 'tmp' file (this is the only one not locked)
- Click the 'Upload file' icon (screenshot 6)
- Locate the CSV file from (your project folder)\apprentice-boot-camp-databases\backend\imports\Product_Offers_Data.csv
- Drag and drop the CSV file into the grey area below
- Click the x on the top-right of the pop-up. The file should now be in the /tmp/ folder (screenshot 7)
- Click 'Select' in the bottom-right and the file should appear as /tmp/Product_Offers_Data.xls
- Format = csv
- Encoding = SQL_ASCII
- Header = Set the toggle on
- Delimiter = , (comma)
Columns tab
- Columns to Import = Select all 5 columns in the order they are in the table from the dropdown (screenshot 9). They may already be pre-populated
-
Click OK on the bottom-right of the import/export wizard to start the import
All being well the data should now be in the staging table
SELECT *
FROM "sequel-mart-schema"."stage_Product_Offers";
data:image/s3,"s3://crabby-images/82127/821271ccf569103bfb35fcfeebca189b2390a119" alt=""
INSERT INTO Product_Offers
Now if we run the following:
INSERT INTO "sequel-mart-schema"."Product_Offers"
(offer_name, product_id, offer_discount_percentage, offer_start_date, offer_end_date)
SELECT offer_name
, product_id
, offer_discount_percentage
, offer_start_date
, offer_end_date
FROM "sequel-mart-schema"."stage_Product_Offers";
we should find the 19 new offers have been inserted into the Product_Offers
table
data:image/s3,"s3://crabby-images/888fb/888fbf931dd1fdf8fc62ed0fa077675b360fa80f" alt=""
and if we query the table we can see the new offers:
SELECT *
FROM "sequel-mart-schema"."Product_Offers";
data:image/s3,"s3://crabby-images/719ec/719ecf7ca5397e9206d8e9aecfdaddb84733715a" alt=""
data:image/s3,"s3://crabby-images/5a0e2/5a0e2201bda3fea043f5b395427eb6891b6563e7" alt=""
data:image/s3,"s3://crabby-images/9a2d2/9a2d2b8ee8f5452588b94a4ae81df11a48e3dfda" alt=""
data:image/s3,"s3://crabby-images/a78a3/a78a30206069a2bb21403b2f5d3dbbf6b9fabf9a" alt=""
data:image/s3,"s3://crabby-images/de19d/de19d5f602a483b04c2d9012d07266d6665f4d3e" alt=""
data:image/s3,"s3://crabby-images/af5b8/af5b8dad662ee78f3dc0fbd55b43be16b4f5e80d" alt=""
data:image/s3,"s3://crabby-images/a65d1/a65d1306a9b185503fc35f2735499f866c64a0ce" alt=""
data:image/s3,"s3://crabby-images/c7c7c/c7c7c0e1c79a741373d73ad4ed88caf35cb8f7b1" alt=""
data:image/s3,"s3://crabby-images/3c375/3c3750e3825340184e1c53f92e66a88d4059170f" alt=""
data:image/s3,"s3://crabby-images/ba2b9/ba2b938d16a311b070eb5d334329c5acd6b51049" alt=""
data:image/s3,"s3://crabby-images/cbc99/cbc995dc459e33174a2eaa5583772c2186bd2fd7" alt=""