

# Aurora DSQL 支持的 SQL
<a name="working-with-postgresql-compatibility-supported-sql-features"></a>

Aurora DSQL 支持各种核心 PostgreSQL SQL 功能。在以下各节中，您可以了解有关 PostgreSQL 表达式的一般支持。此列表并不详尽。

## `SELECT` 命令
<a name="dsql-select"></a>

Aurora DSQL 支持 `SELECT` 命令的以下子句。


| 主要子句 | 支持的子句 | 
| --- | --- | 
| `FROM` |  | 
| `GROUP BY` | `ALL`, `DISTINCT` | 
| `ORDER BY` | `ASC`, `DESC`, `NULLS` | 
| `LIMIT` |  | 
| `DISTINCT` |  | 
| `HAVING` |  | 
| `USING` |  | 
| `WITH`（公用表表达式） |  | 
| `INNER JOIN` | `ON` | 
| `OUTER JOIN` | `LEFT`, `RIGHT`, `FULL`, `ON` | 
| `CROSS JOIN` | `ON` | 
| `UNION` | `ALL` | 
| `INTERSECT` | `ALL` | 
| `EXCEPT` | `ALL` | 
| `OVER` | `RANK ()`, `PARTITION BY` | 
| `FOR UPDATE` |  | 

## 数据定义语言 (DDL)
<a name="dsql-ddl"></a>

Aurora DSQL 支持以下 PostgreSQL DDL 命令。


| 命令 | 主要子句 | 支持的子句 | 
| --- | --- | --- | 
| `CREATE` | `TABLE` | 有关 `CREATE TABLE` 命令支持的语法的信息，请参阅 [`CREATE TABLE`](create-table-syntax-support.md)。 | 
| `ALTER` | `TABLE` | 有关 `ALTER TABLE` 命令支持的语法的信息，请参阅 [`ALTER TABLE`](alter-table-syntax-support.md)。 | 
| `DROP` | `TABLE` |  | 
| `CREATE` | `[UNIQUE] INDEX ASYNC` | 您可以将此命令与以下参数结合使用：`ON`、`NULLS FIRST`、`NULLS LAST`。<br />有关 `CREATE INDEX ASYNC` 命令支持的语法的信息，请参阅 [Aurora DSQL 中的异步索引](working-with-create-index-async.md)。 | 
| `DROP` | `INDEX` |  | 
| `CREATE` | `VIEW` | 有关 `CREATE VIEW` 命令支持的语法的更多信息，请参阅 [`CREATE VIEW`](create-view.md)。 | 
| ALTER | VIEW | 有关 `ALTER VIEW` 命令支持的语法的信息，请参阅 [`ALTER VIEW`](alter-view-syntax-support.md)。 | 
| DROP | VIEW | 有关 DROP VIEW 命令支持的语法的信息，请参阅 [`DROP VIEW`](drop-view-overview.md)。 | 
| `CREATE` | `SEQUENCE` | 有关 `CREATE SEQUENCE` 命令支持的语法的信息，请参阅 [`CREATE SEQUENCE`](create-sequence-syntax-support.md)。 | 
| `ALTER` | `SEQUENCE` | 有关 `ALTER SEQUENCE` 命令支持的语法的信息，请参阅 [`ALTER SEQUENCE`](alter-sequence-syntax-support.md)。 | 
| `DROP` | `SEQUENCE` | 有关 `DROP SEQUENCE` 命令支持的语法的信息，请参阅 [`DROP SEQUENCE`](drop-sequence-syntax-support.md)。 | 
| `CREATE` | `ROLE`, `WITH` |  | 
| `CREATE` | `FUNCTION` | `LANGUAGE SQL` | 
| `CREATE` | `DOMAIN` |  | 

## 数据操作语言 (DML)
<a name="dsql-dml"></a>

Aurora DSQL 支持以下 PostgreSQL DML 命令。


| 命令 | 主要子句 | 支持的子句 | 
| --- | --- | --- | 
| `INSERT` | `INTO` | `VALUES`SELECT | 
| `UPDATE` | `SET` | `WHERE (SELECT)`<br />`FROM, WITH` | 
| DELETE | FROM | USING, WHERE | 

## 数据控制语言（DCL）
<a name="dsql-dcl"></a>

Aurora DSQL 支持以下 PostgreSQL DCL 命令。


| 命令 | 支持的子句 | 
| --- | --- | 
| `GRANT` | `ON`, `TO` | 
| `REVOKE` | `ON`, `FROM`, `CASCADE`, `RESTRICT` | 

## 事务控制语言（TCL）
<a name="dsql-tcl"></a>

Aurora DSQL 支持以下 PostgreSQL TCL 命令。


| 命令 | 支持的子句 | 别名 | 
| --- | --- | --- | 
| `COMMIT` | [`WORK` \| `TRANSACTION`]<br />[`AND NO CHAIN`] | `END` | 
| `BEGIN` | [`WORK` \| `TRANSACTION`]<br />[`ISOLATION LEVEL REPEATABLE READ`]<br />[`READ WRITE` \| `READ ONLY`] |  | 
| `START TRANSACTION` | [`ISOLATION LEVEL REPEATABLE READ`]<br />[`READ WRITE` \| `READ ONLY`] |  | 
| `ROLLBACK` | [`WORK` \| `TRANSACTION`]<br />[`AND NO CHAIN`] | `ABORT` | 

## 实用程序命令
<a name="dsql-utility"></a>

Aurora DSQL 支持以下 PostgreSQL 实用程序命令：
+ `EXPLAIN`
+ `ANALYZE`（仅限关系名称）