开发指南—DQL语句—SELECT

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 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:表示从哪些表中获取数据。
  • WHERE子句:指定查询条件,即从表中获取满足where_condition的行,若没有指定,则获取所有行。
  • GROUP BY子句:支持列名,表达式以及输出列中的位置引用。
  • HAVING子句:与WHERE类似,不同点在于可以使用聚合函数。
  • ORDER BY:指定排序,支持列名、表达式以及输出列中的位置引用,同时支持指定排序方向,ASC(升序)或 DESC(降序)。
  • LIMIT/OFFSET:限定输出结果集的偏移量和大小。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1): 为了与PostgreSQL兼容,MySQL也支持句法: LIMIT # OFFSET #。
  • FOR UPDATE:对查询结果所有行加排他锁,以阻止其他事务的并发修改,或阻止在某些事务隔离级别时的并发读取。

注意事项

  • 不支持在HAVING中使用适用于WHERE子句的表达式,如下SQL1应改写为SQL2。SQL1:
SELECT col_name FROM tbl_name HAVING col_name > 0;
  • SQL2:
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

PolarDB-X支持在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)指定连接两表中都存在的列名,PolarDB-X会按照这些列构建等值条件。如下两条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使用哪个索引,PolarDB-X会将该Hint下推至底层MySQL。
  • 暂不支持STRAIGHT_JOIN和NATURAL JOIN。

UNION

PolarDB-X支持如下UNION语法:


SELECT ...
UNION [ALL | DISTINCT] SELECT ...
[UNION [ALL | DISTINCT] SELECT ...]


说明 对于UNION中的每个SELECT,PolarDB-X暂不支持使用多个同名的列。例如以下SQL的SELECT中存在重复的列名,暂不支持。


SELECT id, id, name FROM t1 UNION SELECT pk, pk, name FROM t2;

相关文档

相关实践学习
Polardb-x 弹性伸缩实验
本实验主要介绍如何对PolarDB-X进行手动收缩扩容,了解PolarDB-X 中各个节点的含义,以及如何对不同配置的PolarDB-x 进行压测。
相关文章
|
SQL 关系型数据库 MySQL
开发指南—DQL语句—子查询
本文介绍PolarDB-X支持的子查询类别及在PolarDB-X中使用子查询的相关限制和注意事项。
开发指南—DML语句—INSERT
您可以使用INSERT语句往表中插入数据。
|
SQL 自然语言处理 关系型数据库
开发指南—DQL语句—SELECT
SELECT用于从一个或多个表中查询数据。
|
8天前
|
人工智能 自然语言处理 API
深入浅出LangChain与智能Agent:构建下一代AI助手
LangChain为大型语言模型提供了一种全新的搭建和集成方式,通过这个强大的框架,我们可以将复杂的技术任务简化,让创意和创新更加易于实现。本文从LangChain是什么到LangChain的实际案例到智能体的快速发展做了全面的讲解。
279536 52
深入浅出LangChain与智能Agent:构建下一代AI助手
|
9天前
|
设计模式 人工智能 JSON
一文掌握大模型提示词技巧:从战略到战术
本文将用通俗易懂的语言,带你从战略(宏观)和战术(微观)两个层次掌握大模型提示词的常见技巧,真正做到理论和实践相结合,占领 AI 运用的先机。
237781 4
|
9天前
|
NoSQL Cloud Native Redis
Redis核心开发者的新征程:阿里云与Valkey社区的技术融合与创新
阿里云瑶池数据库团队后续将持续参与Valkey社区,如过往在Redis社区一样耕耘,为开源社区作出持续贡献。
Redis核心开发者的新征程:阿里云与Valkey社区的技术融合与创新
|
8天前
|
关系型数据库 分布式数据库 数据库
PolarDB闪电助攻,《香肠派对》百亿好友关系实现毫秒级查询
PolarDB分布式版助力《香肠派对》实现百亿好友关系20万QPS的毫秒级查询。
PolarDB闪电助攻,《香肠派对》百亿好友关系实现毫秒级查询
|
2天前
|
机器人 Linux API
基于Ollama+AnythingLLM轻松打造本地大模型知识库
Ollama是开源工具,简化了在本地运行大型语言模型(ile优化模型运行,支持GPU使用和热加载。它轻量、易用,可在Mac和Linux上通过Docker快速部署。AnythingLLM是Mintplex Labs的文档聊天机器人,支持多用户、多种文档格式,提供对话和查询模式,内置向量数据库,可高效管理大模型和文档。它也是开源的,能与Ollama结合使用,提供安全、低成本的LLM体验。这两款工具旨在促进本地高效利用和管理LLMs。
64746 19
|
10天前
|
消息中间件 Cloud Native Serverless
RocketMQ 事件驱动:云时代的事件驱动有啥不同?
本文深入探讨了云时代 EDA 的新内涵及它在云时代再次流行的主要驱动力,包括技术驱动力和商业驱动力,随后重点介绍了 RocketMQ 5.0 推出的子产品 EventBridge,并通过几个云时代事件驱动的典型案例,进一步叙述了云时代事件驱动的常见场景和最佳实践。
225185 2
|
7天前
|
物联网 PyTorch 测试技术
手把手教你捏一个自己的Agent
Modelscope AgentFabric是一个基于ModelScope-Agent的交互式智能体应用,用于方便地创建针对各种现实应用量身定制智能体,目前已经在生产级别落地。