|Data Description Language (DDL)||Data Manipulation Language (DML)||Data Control Language (DCL)||Transaction Control Language (TCL)|
The key actions are:
SELECT [DISTINCT] ... FROM ... UNION [INNER|LEFT|RIGHT|OUTER] JOIN ... ON ... WHERE ... HAVING ... ORDER BY ... [ASC|DESC] LIMIT ... INSERT INTO ... VALUES ... UPDATE ... SET ... [WHERE ...] DELETE ...
SELECT can be used with AS to rename a table or a column.
UNION adds the rows of different queries
HAVING allows aggregate functions.
The order is in fact:
- FROM [UNION/JOIN]
- GROUP BY
- ORDER BY
We have the arithmetic operators +, -, *, /, and %.
Logical/Comparison operators include:
IS NULL IS NOT NULL UNIQUE? =, <, > <>, != NOT, AND, OR BETWEEN ... AND ... EXISTS IN ... LIKE ... ... ANY, ALL
BETWEEN can be numbers, texts, or dates. In the case of text it seems to use alphabetical ordering (Unicode considerations)?
EXISTS tests whether a subquery returns any values (boolean existence check).
IN can use a tuple of values
('George', 'Clooney'), or a subquery.
LIKE uses two wildcards % (0+ characters), and _ (exactly one character). For example,
_r% would mean values with "r" in the 2nd position.
ANY and ALL can be used with an operator against a subquery, e.g.
WHERE column = ANY (SELECT ...).
We have aggregate functions that can act on values:
MIN MAX COUNT AVG SUM
-- comment /* block comment */