一月份的时候有一个考察,但是当时连一个很简单的语句都不会写了,之后就在SQLBolt上进行了一个回顾,这里进行记录,以后方便随时回来查看。
1. SELECT
SELECT * FROM table_name;
2. Queries with constraints
- WHERE clause
SELECT column,...
FORM table
WHERE condition
Operator | SQL Example =-: | :-: BETWEEN … AND … | clo_name BETWEEN 0.5 AND 1.5 NOT BETWEEN … AND … | clo_name NOT BETWEEN 2000 AND 2010 IN (…) | clo_name IN (1, 3, 5) NOT IN (…) | col_name NOT IN (1, 3, 5) 表 1
Operator | Condition | Example =-: | :-: | :-: LIKE | Case insensitive exact string comparison | col_name LIKE ‘abc’ NOT LIKE | Case insensitive exact string inequality comparison | col_name NOT LIKE ‘abc’ % | Match(only with LIKE or NOT LIKE | col_name LIKE ‘%hello%’ _ | Used to match a single character(only with LIKE or NOT LIKE) | col_name LIKE “AN_” IN (…) | String exists in a list | col_name IN (“A”, “B”) NOT IN (…) | String does not exit in a list | col_name NOT IN (“C”, “E”) 表 2
SELECT column,...
FORM table
WHERE condition
  AND/OR another_condition
3. Filtering and sorting Query results
- Unique results
SELECT DISTINCT column, another_column, ...
FROM table_name
WHERE condition(s)
- Ordering results
% Select query with ordered results
SELECT column, another_column, ...
FROM table_name
WHERE condition(s)
ORDER BY column ASC/DESC;
- Limiting results to a subset
% Select query with limited rows
SELECT column, another_column, ...
FROM table_name
WHERE condition(s)
ORDER BY column ASC/DESC
LIMIT num_limit OFFSET num_offset % offset偏移量
eg. List the last four Pixar movies released (ordered from most recent to least)
SELECT * FROM movies
ORDER BY year DESC
LIMIT 4;

eg. List the next five Pixar movies sorted alphabetically
SELECT * FROM movies
ORDER BY title ASC"
LIMIT 5 OFFSET 5;

4. Multi-table queries with JOINs
JOIN clause
- INNER JOIN
% Select query with INNER JOIN on multiple tables
SELECT column, another_table_column, ...
FROM mytable
INNER JOIN another_table
  ON mytable.id = another_table.id
WHERE condition(s)
ORDER BY column, ... ASC/DESC
LIMIT num_limit OFFSET num_offset;
A process that matchs rows from the first table and the second table with have the same key to create a result row with combined columns from both tables.
eg.
SELECT title, rating"
FROM movies
  JOIN boxoffice
    ON movies.id = boxoffice.movie_id
ORDER BY rating DESC;
5. OUTER JOINs
%Select query with LEFT/RIGHT/FULL JOINs on multiple tables
SELECT column, another_column, ...
FROM mytable
INNER/LEFT/RIGHT/FULL JOIN another_table
  ON mytable.id = another_table.matching_id
WHERE condition(s)
ORDER BY column, ... ASC/DESC
LIMIT num_limit OFFSET num_offset;
When joining table A to table B, a
LEFT JOINsimply includes rows from A regardless of whether a matching row is found in B. TheRIGHT JOINis the same, but reversed, keeping rows in B regardless of whether a match is found in A. Finally, aFULL JOINsimply means that rows from both tables are kept, regardless of whether a matching row exists in the other table.
eg. List all buildings and the distinct employee roles in each building (including empty buildings)

SELECT DISTINCT building_name, role FROM buildings
LEFT JOIN employees
  ON buildings.building_name = employees.building
6. A short note on NULLs
Test a column for NULL values in a WHERE clause by using either IS NULL or IS NOT NULL constraint.
%Select query with constraints on NULL values
SELECT column, another_column, ...
FROM mytable
WHERE column IS/IS NOT NULL
AND/OR another_condition
eg.
Find the names of the buildings that hold no employees.

SELECT DISTINCT building_name
FROM buildings
  LEFT JOIN employees
    ON building_name = building
WHERE role IS NULL;
此题需要仔细思考一下
7. Queries with expressions
% Select query with expression aliases
SELECT col_expression AS expr_description, ...
FROM table;
% Example query with both column and table name aliases
SELECT column AS better_column_name, ...
FROM complex_table_name AS easy_table_name;
8. Queries with aggregates(Pt.1)
% Select query with aggregate function over all rows
SELECT AGG_FUNC(column_or_expression) AS aggregate_description, ...
FROM table
WHERE constraint_expression;
- Common aggregate functions
| Function | 
|---|
| COUNT(*) | 
| MIN(column) | 
| MAX(column) | 
| AVG(column) | 
| SUM(column) | 
- Grouped aggregate functions
% Select query with aggregate functions over groups
SELECT AGG_FUNC(column_or_expression) AS aggregate_expression, ...
FROM table
WHERE constraint_expression
GROUP BY column;
The GROUP BY clause works by grouping rows that have the same value in the column specified.
9. Queries with aggregates (Pt. 2)
% Select query with HAVING constraint
SELECT group_by_column, AGG_FUNC(column_expression) AS aggregate_result_alias, ...
FROM table
WHERE condition
GROUP BY column
HAVING group_condition;
The HAVING clause constraints are applied to the grouped rows.
The
HAVINGclause constraints are written the same way as theWHEREclause constraints.
eg. Find the total number of years employed by all Engineers

SELECT role, SUM(years_employed)
FROM employees
GROUP BY role
HAVING role = "Engineer";
result

10. Order of execution of a Query
% Complete SELECT query
SELECT DISTINCT column, AGG_FUNC(column_or_expression), ...
FROM table
  JOIN another_table
    ON table.column = another_table.column
  WHERE constraint_expression
  GROUP BY column
  HAVING constraint_expression
  ORDER BY column ASC/DESC
  LIMIT count OFFSET count;
11. Inserting rows
Inserting new data
- Insert statement with values for all columns
INSERT INTO table
VALUES (value_or_expr, another_value_or_expr, ...),
       (value_or_expr_2, another_value_or_expr_2, ...),
       ...;
- Insert statement with specific columns
INSERT INTO table
(column, another_column, ...)
VALUES (value_or_expr, another_value_or_expr, ...),
       (value_or_expr_2, another_value_or_expr_2, ...),
       ...;
注意string格式的双引号
12. Updating rows
UpdateexistingTdata+08 = ‘00’ -UpdateTstatement with values+08 = ‘00’
UPDATE table
SET column = value_or_expr,
    other_column = another_value_or_expr,
    ...
WHERE condition;
It’s recommended that you run the constraint in a SELECT query first to ensure that you are updating the right rows.
13. Deleting rows
Delete data from a table in the database
- Delete statement with condition
DELETE FROM table
WHERE condition;
It’s recommended that you run the constraint in a SELECT query first to ensure that you are removing the right rows.
14. Creating tables
- Create table statement
CREATE TABLE IF NOT EXISTS table_name (
 column DataType TableConstraint DEFAULT default_value,
    another_column DataType TableConstraint DEFAULT default_value,
    ...
);
Table data types
| Data type | Description | 
|---|---|
| INTEGER, BOOLEAN | |
| FLOAT, DOUBLE, REAL | precise numerical data | 
| CHARACTER, VARCHAR, TEXT | |
| DATE, DATETIME | 
Table constraints
| Constraint | Description | 
|---|---|
| PRIMARY KEY | This means that the values in this column are unique, and each value can be used to identify a single row in this table. | 
| AUTOINCEREMENT(自增) | For integer values, this means that the value is automatically filled in and incremented with each row insertion. | 
| UNIQUE | The values in this column have to be unique | 
| NOT NULL | |
| FOREIGN KEY | This is a consistency check which ensures that each value in this column corresponds to another value in a column in another table. | 
eg.
CREATE TABLE movies (
    id INTEGER PRIMARY KEY,
    title TEXT,"
    director TEXT,
    year INTEGER,
    length_minutes INTEGER
);
15. Altering tables
Adding columns
% Altering table to add new column(s)
ALTER TABLE table_name
ADD column DataType OptionalTableConstraint
  DEFAULT default_value;
Removing columns
% Altering table to remove column(s)
ALTER TABLE table_name
DROP column_to_be_deleted;
Renaming the table
% Altering table name
ALTER TABLE table_name
RENAME TO new_table_name;
16. Dropping tables
- Drop table statement
DROP TABLE IF EXISTS table_name;
IfyouThave another table that is dependent on columns in table you are removing (for example, with a FOREIGN KEY dependency) then you will have to either update all dependent tables first to remove the dependent rows or to remove those tables entirely.+08 = ‘00’
FINISHED: 20_1_29
参考
[1] SQLBolt