Working with Google Cloud SQL: An Introduction to Cloud SQL
Prerequisites
Open Cloud Shell.
Paste the below code.
To export the project id into $PROJECT_ID
$ export PROJECT_ID=$(gcloud info –format=’value(config.project)’)
To print the project id
$ echo $PROJECT_ID
To export the bucket id into $BUCKET
$ export BUCKET=${PROJECT_ID}-ml
To print the bucket id
$ echo $BUCKET
To export the IP address of SQL instance. To get the IP address of SQl Instance Click on this link.
$ MYSQL=<IP_ADDRESS>
To print IP address
$ echo $MYSQL
To open MYSQL connection.
$ mysql –host=$MYSQL –user=root -–password
data:image/s3,"s3://crabby-images/0dd4b/0dd4b5ccf786b77ab042611dd2318b2367263c85" alt=""
Creating database named bts.
$ create database if not exists bts;
Use the database bts
$ use bts;
data:image/s3,"s3://crabby-images/a6fb8/a6fb82f7235ee58e1f5d5cbd77e97610c7dc2a08" alt=""
Creating table trips
create table trips (
vendor_id VARCHAR(16),
pickup_datetime DATETIME,
dropoff_datetime DATETIME,
passenger_count INT,
trip_distance FLOAT,
rate_code VARCHAR(16),
store_and_fwd_flag VARCHAR(16),
payment_type VARCHAR(16),
fare_amount FLOAT,
extra FLOAT,
mta_tax FLOAT,
tip_amount FLOAT,
tolls_amount FLOAT,
imp_surcharge FLOAT,
total_amount FLOAT,
pickup_location_id VARCHAR(16),
dropoff_location_id VARCHAR(16)
);
data:image/s3,"s3://crabby-images/9db2b/9db2bbe68585fee550d0f7f98adca58783cca361" alt=""
$ exit #to exit from mysql.
Paste the below code into shell outside mysql. It’ll copy 2 files from cloud training public bucket.
gsutil cp gs://cloud-training/OCBL013/nyc_tlc_yellow_trips_2018_subset_1.csv trips.csv-1
gsutil cp gs://cloud-training/OCBL013/nyc_tlc_yellow_trips_2018_subset_2.csv trips.csv-2
data:image/s3,"s3://crabby-images/a6bf2/a6bf27a8d4dde2770269334b7d4dbec7362c55e2" alt=""
Open the both files which is created and check whether the content is copied or not.
Using nano editor we’ll open the file. To close the file press Ctrl + X
$ nano trips.csv-1
data:image/s3,"s3://crabby-images/82319/82319679bf3730d7c53920d909c0f3b596b0f504" alt=""
data:image/s3,"s3://crabby-images/3b4e8/3b4e87693d853c23531900264428bee580f028e7" alt=""
$ nano trips.csv-2
data:image/s3,"s3://crabby-images/3b62f/3b62f5819d7dd8383bbe1375b9ff6087a45d0dcc" alt=""
data:image/s3,"s3://crabby-images/b892b/b892b7c2dcb2ba91af64a833a93d602d92a74411" alt=""
Importing the database content into mysql.
$ mysqlimport –local –host=$MYSQL –user=root –password –ignore-lines=1 –fields-terminated-by=’,’ bts trips.csv-*
data:image/s3,"s3://crabby-images/2a479/2a4795687613e3ea9e29d9f913220da900c00944" alt=""
Open mysql. Type the password. Password won’t be visible.
$ mysql –host=$MYSQL –user=root –password
data:image/s3,"s3://crabby-images/0cf6d/0cf6db12cad8194f8e37caf990cf2643effaf7d2" alt=""
To use the bts database.
$ use bts;
data:image/s3,"s3://crabby-images/999af/999af13c2407032fb44c2d62453e8062357e8a71" alt=""
SQL queries
$ select distinct(pickup_location_id) from trips limit 5;
data:image/s3,"s3://crabby-images/62c53/62c53dc54c025a507f1ca241f341dc88bc979a1e" alt=""
$ select
max(trip_distance),
min(trip_distance)
from trips;
data:image/s3,"s3://crabby-images/56500/56500361c363535745540ed044dcbad636383ca7" alt=""
$ select count(*) from trips where trip_distance=0;
data:image/s3,"s3://crabby-images/a0314/a0314ec60cb49312e4aac8552f34daeb78b77de7" alt=""
$ select count(*) from trips where fare_amount=0;
data:image/s3,"s3://crabby-images/7efb7/7efb7778f546ab386a54434dba596d78aa04c406" alt=""
$ select
payment_type,
count(*) from trips
group by payment_type;
data:image/s3,"s3://crabby-images/fb206/fb20637fc8f833908a062a17fbc0e824c955fde8" alt=""
$ show tables;
data:image/s3,"s3://crabby-images/23fe6/23fe6f023aaf313258b7b78fcd0784eb29a2dd9d" alt=""
$ desc trips;
data:image/s3,"s3://crabby-images/75db9/75db98d080c52a8595051073ec7bd2fb61b6955b" alt=""
Working with Google Cloud SQL: An Introduction to Cloud SQL