PolarDB-X 1.0-SQL 手册-DML-SELECT

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
简介: 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 {[offs

SELECT 用于从一个或多个表中查询数据。


  1. SELECT
  2.    [ALL | DISTINCT]
  3.    select_expr [, select_expr ...]
  4.    [FROM table_references
  5.    [WHERE where_condition]
  6.    [GROUP BY {col_name | expr | position}
  7.    [HAVING where_condition]
  8.    [ORDER BY {col_name | expr | position}
  9.      [ASC | DESC],...]
  10.    [LIMIT {[offset,] row_count | row_count OFFSET offset}]
  11.    [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 中的表达式,如:
  1. SELECT col_name FROM tbl_name HAVING col_name >0;
  • 应改成如下 SQL:
  1. SELECT col_name FROM tbl_name WHERE col_name >0;
  • HAVING 子句可以引用聚合函数,但 WHERE 子句不可以
  1. SELECT user, MAX(salary) FROM users
  2. GROUP BY user HAVING MAX(salary)>10;
  • LIMIT 若有两个参数,第一个参数表示返回第一行的偏移量,第二个参数表示返回的行数;若仅有一个参数,则表示返回的行数,默认偏移量为 0
  • GROUP BY 子句不支持 ASC 和 DESC
  • 同时存在 GROUP BY 和 ORDER BY 时,ORDER BY 后面的表达式必须在 SELECT 表达式或 GROUP BY 表达式中,如不支持以下 SQL:
  1. SELECT user FROM users GROUP BY age ORDER BY salary;
  • 暂不支持 ORDER BY 子句中使用聚合函数以及包含聚合函数的表达式,可将表达式作为 select_expr,并赋予别名,在 ORDER BY 子句中引用该别名
  • 暂不支持以空字符串作为别名

JOIN 语法

PolarDB-X 支持在 SELECT 语句的 table_references 中使用如下 JOIN 语法:


  1. table_references:
  2.    escaped_table_reference [, escaped_table_reference]...

  3. escaped_table_reference:
  4.    table_reference
  5.  |{ OJ table_reference }

  6. table_reference:
  7.    table_factor
  8.  | join_table

  9. table_factor:
  10.    [schema_name.]tbl_name [[AS]alias][index_hint_list]
  11.  | table_subquery [AS]alias
  12.  |( table_references )

  13. join_table:
  14.    table_reference [INNER | CROSS] JOIN table_factor [join_condition]
  15.  | table_reference {LEFT|RIGHT}[OUTER] JOIN table_reference join_condition

  16. join_condition:
  17.    ON conditional_expr
  18.  | USING (column_list)

  19. index_hint_list:
  20.    index_hint [, index_hint]...

  21. index_hint:
  22.    USE {INDEX|KEY}
  23.      [FOR {JOIN|ORDER BY|GROUP BY}]([index_list])
  24.  | IGNORE {INDEX|KEY}
  25.      [FOR {JOIN|ORDER BY|GROUP BY}](index_list)
  26.  | FORCE {INDEX|KEY}
  27.      [FOR {JOIN|ORDER BY|GROUP BY}](index_list)

  28. index_list:
  29.    index_name [, index_name]...

使用 JOIN 语句时,应考虑如下因素:

  • JOIN,CROSS JOIN 与 INNER JOIN 是语法等价的,这种设定与 MySQL 保持一致
  • 如果 INNER JOIN 没有 ON 条件,其与 ‘逗号’ 连接是等价的,均表示笛卡尔积。如下两条 SQL 等价:
  1. SELECT * FROM t1 INNER JOIN t2 WHERE t1.id >10
  2. SELECT * FROM t1, t2 WHERE t1.id >10
  • USING(column_list) 指定连接两表中都存在的列名,PolarDB-X 会按照这些列构建等值条件。如下两个 SQL 片段等价:
  1. a LEFT JOIN b USING(c1, c2)
  2. 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 使用哪个索引,PolarDB-X 会将该 Hint 下推至底层 MySQL。
  • 暂不支持STRAIGHT_JOIN和 NATURAL JOIN。

UNION 语法

PolarDB-X 支持如下 UNION 语法:


  1. SELECT ...
  2. UNION [ALL | DISTINCT] SELECT ...
  3. [UNION [ALL | DISTINCT] SELECT ...]

注意:对于 UNION 中的每个 SELECT, PolarDB-X 暂不支持使用多个同名的列,如下:


  1. # 如下 SQL 的 SELECT 中存在重复的列名,暂不支持
  2. SELECT id, id, name FROM t1 UNION SELECT pk, pk, name FROM t2;

相关文献

相关实践学习
快速体验PolarDB开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
相关文章
|
4月前
|
SQL 存储 关系型数据库
关系型数据库SQLserver基本 SQL 操作
【7月更文挑战第28天】
35 4
|
3月前
|
SQL 安全 关系型数据库
关系型数据库SQL server DELETE 语句
【8月更文挑战第3天】
76 10
|
3月前
|
SQL 关系型数据库 数据库
关系型数据库SQL server UPDATE 语句
【8月更文挑战第3天】
68 10
|
3月前
|
SQL 关系型数据库 BI
关系型数据库SQL server INSERT 语句
【8月更文挑战第3天】
61 9
|
4月前
|
SQL 关系型数据库 分布式数据库
PolarDB产品使用问题之遇到慢SQL问题,该如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
4月前
|
SQL 存储 监控
|
3月前
|
SQL 关系型数据库 数据库
|
3月前
|
SQL 关系型数据库 数据库
|
4月前
|
SQL 关系型数据库 分布式数据库
PolarDB产品使用问题之sql运行报错是神么原因
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
4月前
|
SQL 关系型数据库 Serverless
PolarDB产品使用问题之如何控制队列中排队的SQL的等待时间
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。

相关产品

  • 云原生分布式数据库 PolarDB-X
  • 下一篇
    无影云桌面