Skip to Content

This Complete SQL Cheat Sheet Makes Learning Clear and Easy

Learning SQL can often feel overwhelming due to its extensive range of commands, functions, and syntax rules.

To simplify this process and make SQL more accessible, we’ve created a comprehensive chart designed to streamline your learning experience.

This chart serves as an all-in-one reference tool, helping you grasp and apply SQL concepts more effectively.

With this chart, you can quickly access key SQL commands, functions, and operators.

Get Your Linux Course!

Join our Linux Course and discover the power of open-source technology. Enhance your skills and boost your career! Learn Linux today!

It eliminates the need to memorize every detail, allowing you to focus on learning and applying SQL more efficiently.

Table of Contents

SQL Commands

  • Data Manipulation Language (DML): SELECT, INSERT, UPDATE, DELETE
  • Data Definition Language (DDL): CREATE, ALTER, DROP
  • Data Control Language (DCL): GRANT, REVOKE

SQL Functions

  • String Functions: LENGTH(), CONCAT(), SUBSTRING()
  • Date Functions: NOW(), CURDATE(), DATE_FORMAT()
  • Aggregate Functions: COUNT(), SUM(), AVG(), MAX(), MIN()

SQL Operators

  • Arithmetic Operators: +, -, *, /
  • Comparison Operators: =, !=, <, >, <=, >=
  • Logical Operators: AND, OR, NOT

SQL Clauses

  • WHERE: Filters records based on conditions
  • GROUP BY: Groups rows sharing a property
  • ORDER BY: Sorts the result set
  • JOIN: Combines rows from multiple tables

SQL Constraints

  • NOT NULL: Ensures a column cannot have NULL values
  • UNIQUE: Ensures all values in a column are distinct
  • PRIMARY KEY: Uniquely identifies each row in a table
  • FOREIGN KEY: Maintains referential integrity between tables
  • CHECK: Ensures values satisfy specific conditions

Querying Data From Table ✔️

These code blocks are used to access the data from a single table. Certainly, it has a SELECT and FROM statement, but along with that there are multiple use-cases as you can see below.

Query data in columns column_1, column_2 from a table table_1

SELECT column_1, column_2
FROM table_1;

Query all rows and columns from a table table_1

SELECT * 
FROM table_1;

Query data and filter rows with a condition

SELECT column_1, column_2
FROM table_1
WHERE condition;

Query distinct rows from a table

SELECT DISTINCT column_1
FROM table_1
WHERE condition;

Sort the result set in ascending or descending order

SELECT column_1, column_2
FROM table_1
ORDER BY column_1 DESC;
-- The default order is ascending, the keyword DESC in ORDER BY stands for descending

Skip offset of rows and return the next n rows

SELECT column_1, column_2
FROM table_1
ORDER BY column_1 
LIMIT n OFFSET offset;

Group rows using an aggregate function

SELECT column_1, aggregate(column_2)
FROM table_1
GROUP BY column_1;

Filter groups using the HAVING clause

SELECT column_1, aggregate(column_2)
FROM table_1
GROUP BY column_1
HAVING condition;

Querying From Multiple Tables ✔️

These queries are used to pull the data from multiple tables by joining them together. Therefore, these queries involve joins as given below,

Inner join tables: table_1 and table_2

SELECT column_1, column_2
FROM table_1
INNER JOIN table_2 ON condition;

Left join tables: table_1 and table_2

SELECT column_1, column_2
FROM table_1
LEFT JOIN table_2 ON condition;

Right join tables: table_1 and table_2

SELECT column_1, column_2
FROM table_1
RIGHT JOIN table_2 ON condition;

Perform full outer join

SELECT column_1, column_2
FROM table_1
FULL OUTER JOIN table_2 ON condition;

Produce a Cartesian product of rows in tables

SELECT column_1, column_2
FROM table_1
CROSS JOIN table_2;

Produce a Cartesian product of rows in tables without cross join

SELECT column_1, column_2
FROM table_1, table_2;

Join table to itself using INNER JOIN clause

SELECT column_1, column_2
FROM table_1 A
INNER JOIN table_1 B ON condition;

Using SQL Operators ✔️

These queries use mathematical and logical operators to extract data based on a condition as shown below.

Combine rows from two queries

SELECT column_1, column_2
FROM table_1
UNION ALL
SELECT column_1, column_2
FROM table_2;

Return the intersection of two queries

SELECT column_1, column_2
FROM table_1
INTERSECT
SELECT column_1, column_2
FROM table_2;

Subtract a result set from another result set

SELECT column_1, column_2
FROM table_1
MINUS
SELECT column_1, column_2
FROM table_2;

Query rows using pattern matching %, _

SELECT column_1, column_2
FROM table_1
WHERE column_1 LIKE pattern;
-- LIKE: Case-sensitive search for a pattern with a wildcard operator (%)
-- NOT LIKE: Returns the rows which are not matching with Case-sensitive pattern

Query rows in a list

SELECT column_1, column_2
FROM table_1
WHERE column_1 IN (value_list);
-- IN: Returns the rows when Column_1 value is present in value_list
-- NOT IN: Returns the rows when Column_1 value is not present in value_list

Query rows between two values: low and high

SELECT column_1, column_2
FROM table_1
WHERE column_1 BETWEEN low AND high;

Check if values in a table are NULL or not

SELECT column_1, column_2
FROM table_1
WHERE column_1 IS NULL;
-- NULL: Returns the rows when Column_1 value is NULL
-- NOT NULL: Returns the rows when Column_1 value is not NULL

Managing Tables ✔️

These queries are used to perform operations for managing the tables such as create, update, delete, and many more as shown below.

Create a new table with three columns: column_1, column_2, column_3

CREATE TABLE table_1 (
     column_1 INT PRIMARY KEY,
     column_2 VARCHAR NOT NULL,
     column_3 INT DEFAULT 0
);

Delete the table from the database

DROP TABLE table_1;

Add a new column — column_1 — to the table

ALTER TABLE table_1 ADD column_1;

Drop column — column_1 — from the table

ALTER TABLE table_1 DROP COLUMN column_1;

Add a constraint

ALTER TABLE table_1 ADD CONSTRAINT constraint_name;

Drop a constraint

ALTER TABLE table_1 DROP CONSTRAINT constraint_name;

Rename a table from table_1 to table_2

ALTER TABLE table_1 RENAME TO table_2;

Rename column column_1 to column_2

ALTER TABLE table_1 RENAME COLUMN column_1 TO column_2;

Remove all data in a table

TRUNCATE TABLE table_1;

Using SQL Constraints ✔️

These queries are used to specify rules for the data in a table. Constraints limit the type of data that can go into a table. This ensures the accuracy and reliability of the data in the table. This includes statements as below,

Set column_1 and column_2 as a primary key

CREATE TABLE table_1(
    column_1 INT, column_2 INT, column_3 VARCHAR,
    PRIMARY KEY (column_1, column_2)
);

Set column — column_2 — as a foreign key

CREATE TABLE table_1(
    column_1 INT PRIMARY KEY,  
    column_2 INT,
    FOREIGN KEY (column_2) REFERENCES table_2(column_2)
);

Ensure column_1 > 0 and values in column_1 >= column_2

CREATE TABLE t(
  column_1 INT, column_2 INT,
  CHECK(column_1 > 0 AND column_1 >= column_2)
);

Set values in column — column_2 — not NULL

CREATE TABLE t(
     column_1 INT PRIMARY KEY,
     column_2 VARCHAR NOT NULL
);

Modifying Data ✔️

These queries are used to deal with already present tables. This includes operations such as inserting, changing, and deleting values as shown below,

Insert one row into a table

INSERT INTO table_1(column_list)
VALUES(value_list);

Insert multiple rows into a table

INSERT INTO table_1(column_list)
VALUES (value_list), 
       (value_list), ...;

Insert rows from table_2 into table_1

INSERT INTO table_1(column_list)
SELECT column_list
FROM table_2;

Update the new value in the column — column_1 — for all rows

UPDATE table_1
SET column_1 = new_value;

Update values in the columns column_1, column_2 that match the condition

UPDATE table_1
SET column_1 = new_value, 
    column_2 = new_value
WHERE condition;

Delete all data in a table

DELETE FROM table_1;

Delete subset of rows in a table

DELETE FROM table_1
WHERE condition;

Managing Views ✔️

A VIEW in SQL Server is like a virtual table that contains data from one or multiple tables. It does not hold any data and does not exist physically in the database. These queries are used to perform operations to manage views as shown below,

Create a new view that consists of column_1 and column_2

CREATE VIEW view_1(column_1, column_2) 
AS
SELECT column_1, column_2
FROM table_1;

Create a new view with the check option

CREATE VIEW view_1(column_1, column_2) 
AS
SELECT column_1, column_2
FROM table_1
WITH [CASCADED | LOCAL] CHECK OPTION;

Create a recursive view

CREATE RECURSIVE VIEW view_1 
AS
select-statement -- anchor part
UNION ALL
select-statement; -- recursive part

Create a temporary view

CREATE TEMPORARY VIEW view_1
AS
SELECT column_1, column_2
FROM table_1;

Delete a view

DROP VIEW view_name;