SELECT
SELECT 用于从一个或多个表中查询数据。
SELECT
[ALL | DISTINCT]
select_expr [, select_expr ...]
[FROM table_references
[WHERE where_condition]
[GROUP BY {col_name | expr | position}
[HAVING where_condition]
[ORDER BY {col_name | expr | position}
[ASC | DESC], ...]
[LIMIT {[offset,] row_count | row_count OFFSET offset}]
[FOR UPDATE]
SELECT 子句说明:
- select_expr 表示查询的列,SELETE 必须至少有一个 select_expr
- table_references 表示从哪些表中获取数据,参考 JOIN 语法
- WHERE 子句指定查询条件,即从表中获取满足 where_condition 的行,若没有指定,则获取所有行
- GROUP BY 子句支持列名,表达式以及输出列中的位置引用
- HIVING 子句与 WHERE 类似,不同点在于可以使用聚合函数
- ORDER BY 指定排序,支持列名,表达式以及输出列中的位置引用,同时支持指定排序方向,ASC(升序)或 DESC(降序)
- LIMIT/OFFSET 限定输出结果集的偏移量和大小,支持两种语法:LIMIT 接受一个或者两个数字参数或者 LIMIT … OFFSET …
- FOR UPDATE 对查询结果所有行加排他锁,以阻止其他事务的并发修改,或阻止在某些事务隔离级别时的并发读取
以下是使用 SELECT 时应注意的一些事项:
- 不要在 HAVING 中使用应该在 WHERE 中的表达式,如:
应改成如下 SQL:SELECT col_name FROM tbl_name HAVING col_name > 0;
SELECT col_name FROM tbl_name WHERE col_name > 0;
- HAVING 子句可以引用聚合函数,但 WHERE 子句不可以
SELECT user, MAX(salary) FROM users
GROUP BY user HAVING MAX(salary) > 10;
- LIMIT 若有两个参数,第一个参数表示返回第一行的偏移量,第二个参数表示返回的行数;若仅有一个参数,则表示返回的行数,默认偏移量为 0
- GROUP BY 子句不支持 ASC 和 DESC
- 同时存在 GROUP BY 和 ORDER BY 时,ORDER BY 后面的表达式必须在 SELECT 表达式或 GROUP BY 表达式中,如不支持以下 SQL:
SELECT user FROM users GROUP BY age ORDER BY salary;
- 暂不支持 ORDER BY 子句中使用聚合函数以及包含聚合函数的表达式,可将表达式作为 select_expr,并赋予别名,在 ORDER BY 子句中引用该别名
- 暂不支持以空字符串作为别名
JOIN 语法
DRDS 支持在 SELECT 语句的 table_references 中使用如下 JOIN 语法:
table_references:
escaped_table_reference [, escaped_table_reference] ...
escaped_table_reference:
table_reference
| { OJ table_reference }
table_reference:
table_factor
| join_table
table_factor:
[schema_name.]tbl_name [[AS] alias] [index_hint_list]
| table_subquery [AS] alias
| ( table_references )
join_table:
table_reference [INNER | CROSS] JOIN table_factor [join_condition]
| table_reference {LEFT|RIGHT} [OUTER] JOIN table_reference join_condition
join_condition:
ON conditional_expr
| USING (column_list)
index_hint_list:
index_hint [, index_hint] ...
index_hint:
USE {INDEX|KEY}
[FOR {JOIN|ORDER BY|GROUP BY}] ([index_list])
| IGNORE {INDEX|KEY}
[FOR {JOIN|ORDER BY|GROUP BY}] (index_list)
| FORCE {INDEX|KEY}
[FOR {JOIN|ORDER BY|GROUP BY}] (index_list)
index_list:
index_name [, index_name] ...
使用 JOIN 语句时,应考虑如下因素:
- JOIN,CROSS JOIN 与 INNER JOIN 是语法等价的,这种设定与 MySQL 保持一致
- 如果 INNER JOIN 没有 ON 条件,其与 ‘逗号’ 连接是等价的,均表示笛卡尔积。如下两条 SQL 等价:
SELECT * FROM t1 INNER JOIN t2 WHERE t1.id > 10
SELECT * FROM t1, t2 WHERE t1.id > 10
- USING(column_list) 指定连接两表中都存在的列名,DRDS 会按照这些列构建等值条件。如下两个 SQL 片段等价:
a LEFT JOIN b USING(c1, c2)
a LEFT JOIN b ON a.c1 = b.c1 AND a.c2 = b.c2
- JOIN 的优先级高于’逗号’操作符,对于连接表达式 t1, t2 JOIN t3 会转换为 (t1, (t2 JOIN t3),而不是 ((t1, t2) JOIN t3)
- 外连接 LEFT/RIGHT JOIN 必须有 ON 条件
- index_hint 用于告知 MySQL 使用哪个索引,DRDS 会将该 Hint 下推至底层 MySQL
- 暂不支持 STRAIGHT_JOIN 和 NATURAL JOIN
UNION 语法
DRDS 支持如下 UNION 语法:
SELECT ...
UNION [ALL | DISTINCT] SELECT ...
[UNION [ALL | DISTINCT] SELECT ...]
注意:对于 UNION 中的每个 SELECT, DRDS 暂不支持使用多个同名的列,如下:
# 如下 SQL 的 SELECT 中存在重复的列名,暂不支持
SELECT id, id, name FROM t1 UNION SELECT pk, pk, name FROM t2;
相关文献
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。
评论