paint-brush
You Don't Need More Than 2 Weeks to Learn Basic SQLby@justanotherteachlead
New Story

You Don't Need More Than 2 Weeks to Learn Basic SQL

by Just Another Tech Lead7mDecember 24th, 2024
Read on Terminal Reader
Read this story w/o Javascript
tldt arrow

Too Long; Didn't Read

The time it takes to learn SQL can really vary depending on your background, the time you get to spend learning and your aptitude towards this type of task.
featured image - You Don't Need More Than 2 Weeks to Learn Basic SQL
Just Another Tech Lead HackerNoon profile picture
0-item
1-item

SQL stands for structured query language.


I’m not going to call SQL a programming language, as in my opinion, it’s not.


SQL is a query language. That means that when you piece the query language together, it’s to retrieve data based on the rules that your query defines.


There’s a lot (I repeat, a lot!) of uses for basic SQL.


Software Engineers uses SQL, data science uses SQL, data analytics uses SQL, heck, even accountants use SQL.


SQL skills and thought process can also be translated to a lot of different ETL based tasks.


If you know the SQL basics, you can boost your employability for sure.


You also don’t need a lot to start to learn. A decent laptop and a free mySQL install and you’re good to go.


In my mind, learning of any programming related topic is not a sprint, it’s a marathon. With that in mind though, lets' look at some realistic timelines for learning SQL.

Benefits of Learning SQL


binary code, binary, binary system


Structured query language (SQL) is common anywhere that requires database systems.


And guess where database systems are used? Pretty much everywhere.


If you are interested in data analytics, data science, software engineering, or database management, you will need to know SQL.


Learning SQL can also lead to high-paying jobs that involve other programming languages.

Factors Affecting Learning Speed for Programming Languages



big data, data, database


For starters, you need to be able to dedicate some time to learning.


When I started as a Junior Software Engineer 20 years ago, I was fortunate enough to get paid to learn. I was able to spend hours reading, taking courses and practicing in real world experiences.


If you can learn on the job, it’s certainly easier. You may be cross training from other programming languages, or from a completely different department.


Either way, being in the proximity of a SQL developer aids the learning process, that’s for sure.


If you are not learning on the job, there are lots of amazing course providers out there that offer courses in both basic SQL and advanced SQL skills. Without someone to guide you through though, factor in that this will take a little longer.

Learning Structured Query Language (SQL): A Step-by-Step Guide

Beginner Level: SQL Fundamentals

Let’s quickly go through the basics:

SELECT statement

-- Select all columns from the 'users' table
SELECT * 
FROM users;

-- Select specific columns (e.g., 'id', 'name') from the 'users' table
SELECT id, name, email 
FROM users 
WHERE status = 'active';

INSERT statement

-- Insert a single row into the 'users' table
INSERT INTO users (id, name, email, status) 
VALUES (1, 'John Doe', 'johndoe@example.com', 'active');

-- Insert multiple rows into the 'users' table
INSERT INTO users (id, name, email, status) 
VALUES 
(2, 'Jane Smith', 'janesmith@example.com', 'inactive'),
(3, 'Sam Wilson', 'samwilson@example.com', 'active');

UPDATE statement

-- Update the 'status' column for a specific user
UPDATE users
SET status = 'inactive'
WHERE id = 1;

-- Update multiple columns for users with a certain condition
UPDATE users
SET email = 'newemail@example.com', status = 'active'
WHERE name = 'Jane Smith';

DELETE statement

-- Delete a specific row based on a condition
DELETE FROM users
WHERE id = 1;

-- Delete all rows where status is 'inactive'
DELETE FROM users
WHERE status = 'inactive';

Learning these basic SQL concepts can be done in a few days.

Intermediate Level: Advanced SQL Concepts


database, data, technology


How long does it take to learn SQL to an intermediate level? A year or two to do it properly.


Intermediate sql skills here.


SQL Functions, JOINs, Subqueries and CTEs.


This is to learn how to manipulate data using SQL queries.

JOINS

INNER JOIN with a WHERE clause.

-- Retrieve users and their corresponding orders
SELECT users.id, users.name, orders.order_id, orders.amount
FROM users
INNER JOIN orders ON users.id = orders.user_id
WHERE orders.amount > 100;

This query joins the ‘users’ table and the ‘orders’ table where the ‘id’ in ‘users’ matches the ‘user_id’ in ‘orders’.


LEFT JOIN

-- Retrieve all users and their orders (include users with no orders)
SELECT users.id, users.name, orders.order_id, orders.amount
FROM users
LEFT JOIN orders ON users.id = orders.user_id;

CTEs

-- Use a CTE to retrieve users with high order amounts
WITH HighSpendingUsers AS (
    SELECT users.id, users.name, SUM(orders.amount) AS total_spent
    FROM users
    INNER JOIN orders ON users.id = orders.user_id
    GROUP BY users.id, users.name
    HAVING SUM(orders.amount) > 500
)
SELECT * 
FROM HighSpendingUsers;

-- Explanation:
-- 1. The CTE 'HighSpendingUsers' calculates the total spent by each user.
-- 2. Only users with a total order amount greater than 500 are included.
-- 3. The main query selects all results from the CTE.

Subqueries

-- Retrieve users and the total amount of their orders
SELECT 
    id, 
    name, 
    (SELECT SUM(amount) FROM orders WHERE orders.user_id = users.id) AS total_spent
FROM users;

Practice with complex queries and data analysis using the above features and you’ll be well in to your intermediate SQL skills level.

Advanced Level: Specialized Topics

How long does it take to learn SQL to an advanced level? Probably years.


Everyones learning process is different, but to truly master the above skill set and understand not only how to use the features, but when to use them should be achievable in 3 to 6 months depending on how many hours a day you are able to practice and learn.


Let’s move on the advanced SQL functions.

Stored Procedures

A stored procedure is a collection of individual SQL statements placed together to make a reusable set of combined functionality.


You would usually pass a few parameters in to the stored procedure, it would use those parameters to define the data required and then return you something hopefully useful.

-- Create a stored procedure to fetch user details by user ID
CREATE PROCEDURE GetUserById
    @UserId INT
AS
BEGIN
    -- Select statement to return the user object
    SELECT id, name, email, status
    FROM users
    WHERE id = @UserId;
END;


Above, we have a stored procedure. It takes userId as an input, and returns a row of data from the ‘users’ table, containing the columns: Id, name, email and status.


To execute the stored procedure, we simply:

-- Execute the stored procedure with a specific UserId
EXEC GetUserById @UserId = 1;

and it returns (assuming the data is present):

id    | name       | email              | status
1     | John Doe   | johndoe@mail.com   | active

Database Performance

Advanced users will need to take time to learn about database performance.


Sometimes you will have a database administrator to help you with this, but other times as an engineer, you’ll be on your own.


Advanced SQL then isn’t just about syntax, it’s about understanding how to write complex queries to manipulate data on a relational database.

Effective Learning Strategies

As always with programming languages, you need to start at the beginning and take your time.


I learned on the job and picked a lot up as I went as and when I needed.


My SQL skills came as I needed to solve new problems and manipulate data in ways I hadn’t before.


Learning SQL for me was a mix of reading books (this was 20 years ago!), taking courses, pair programming and diving deep when coming across a stumbling block in a project.


Practice as often as you can with real world scenarios. There’s nothing better than solving an actual problem rather than a contrived example.


Get involved with communities. The microsoft sql server groups on LinkedIn are great. Friendly people with a lot of knowledge.

So how Long Does It Take to Learn SQL?



never stop learning, continuing education, learning


As always, questions like this are very hard to answer universally.


The time it takes to learn SQL can really vary depending on your background, the time you get to spend learning and your aptitude towards this type of task.


If you have no programming knowledge, learning very basic SQL skills can take up to around two weeks.


Intermediate SQL skills can be picked up in the first few months of dedicated work, and I’d say that advanced SQL skills will take up to a year of solid work.


If you are already familiar with other programming languages and have prior programming experience, or have used relational databases before, learning SQL could be much faster than that.


Just remember, don’t be hard on yourself. It takes time and most people genuinely have what it takes to learn SQL.

Just Another Tech Lead - Software Engienering, Tech and People Leadership