在亚马逊中使用 partiQL 查询 Ion QLDB - 亚马逊 Quantum Ledger 数据库(亚马逊QLDB)

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

在亚马逊中使用 partiQL 查询 Ion QLDB

重要

终止支持通知:现有客户可以在2025年7月31日终止支持QLDB之前使用亚马逊。有关更多详细信息,请参阅将亚马逊QLDB账本迁移到亚马逊 Aurora Postgr SQL e。

当您在亚马逊中查询数据时QLDB,您以 PartiQL 格式编写语句,但会以 Amazon Ion 格式QLDB返回结果。PartiQL 旨在SQL兼容,而 Ion 则是的扩展。JSON这会导致在查询语句中对数据进行注释的方式与查询结果显示方式在语法上存在差异。

本节介绍使用QLDB控制台或 QLDB shell 手动运行 PartiQL 语句的基本语法和语义。

提示

当以编程方式运行 PartiQL 查询时,最佳做法是使用参数化语句。可在语句中使用问号(?)作为绑定变量占位符,以避免使用这些语法规则。这也更安全和高效。

若要了解更多信息,请参阅驱动程序入门中的以下教程:

语法和语义

使用QLDB控制台或 QLDB shell 查询 Ion 数据时,以下是 PartiQL 的基本语法和语义:

区分大小写

所有QLDB系统对象名称(包括字段名、表名和账本名称)均区分大小写。

字符串值

在 Ion 中,双引号("...")表示字符串

在 PartiQL 中,单引号('...')表示字符串。

符号和标识符

在 Ion 中,单引号('...')表示符号。Ion 中称为标识符的符号子集由未加引号的文本表示。

在 PartiQL 中,双引号("...")表示带引号的 PartiQL 标识符,如用作表名的保留字。未加引号的文本表示常规 PartiQL 标识符,例如非保留字的表名。

Ion 文本

在 PartiQL 语句中,任何 Ion 文字都可以用反引号(`...`)表示。

字段名称

Ion 字段名称区分大小写。PartiQL 允许您在语句中用单引号表示字段名。DML这是使用 PartiQL cast函数定义符号的简写替代方案。它也比使用反引号表示字面上的 Ion 符号更直观。

文本

PartiQL 查询语言的字面值对应 Ion 数据类型,如下所示:

标量

如果适用,请按照PartiQL-ion 类型映射第节中所述的SQL语法进行操作。例如:

  • 5

  • 'foo'

  • null

Structs

也称为多种格式的元组或对象、以及其他数据模型。

用大括号({...})表示,其中struct元素用逗号分隔。

  • { 'id' : 3, 'arr': [1, 2] }

列表

也被称为数组。

用方括号([...])表示,列表元素以逗号分隔。

  • [ 1, 'foo' ]

数据包

PartiQL 中的无序集合。

用双尖括号(<<...>>)表示,数据包元素用逗号隔开。在中QLDB,桌子可以看作是一个袋子。但是,数据包不能嵌套在表格中的文档中。

  • << 1, 'foo' >>

示例

下面是具有各种 Ion 类型INSERT语句的语法示例。

INSERT INTO VehicleRegistration VALUE { 'VIN' : 'KM8SRDHF6EU074761', --string 'RegNum' : 1722, --integer 'State' : 'WA', 'City' : 'Kent', 'PendingPenaltyTicketAmount' : 130.75, --decimal 'Owners' : { --nested struct 'PrimaryOwner' : { 'PersonId': '294jJ3YUoH1IEEm8GSabOs' }, 'SecondaryOwners' : [ --list of structs { 'PersonId' : '1nmeDdLo3AhGswBtyM1eYh' }, { 'PersonId': 'IN7MvYtUjkp1GMZu0F6CG9' } ] }, 'ValidFromDate' : `2017-09-14T`, --Ion timestamp literal with day precision 'ValidToDate' : `2020-06-25T` }

反引号表示法

PartiQL 完全涵盖所有 Ion 数据类型,因此您无需使用反引号即可编写任何语句。但是在某些情况下,这种 Ion 文字语法可以让您的语句更清晰、更简洁。

例如,要插入带有 Ion 时间戳和符号值的文档,可仅使用纯粹的 PartiQL 语法编写以下语句。

INSERT INTO myTable VALUE { 'myTimestamp': to_timestamp('2019-09-04T'), 'mySymbol': cast('foo' as symbol) }

这相当冗长,所以你可改用反引号简化你的语句。

INSERT INTO myTable VALUE { 'myTimestamp': `2019-09-04T`, 'mySymbol': `foo` }

您也可以用反引号将整个结构括起,以节省更多的按键次数。

INSERT INTO myTable VALUE `{ myTimestamp: 2019-09-04T, mySymbol: foo }`
重要

在 PartiQL 中,字符串和符号类别不同。这意味着,即使它们有相同的文本,也不相等。例如,以下 PartiQL 表达式计算为不同 Ion 值。

'foo'
`foo`

路径导航

在编写数据操作语言 (DML) 或查询语句时,您可以使用路径步骤访问嵌套结构中的字段。PartiQL 支持使用点表示法访问父结构的字段名称。以下示例访问父项 VehicleModel 字段。

Vehicle.Model

若要访问列表中的特定元素,可以使用方括号运算符表示从零开始的序数。以下示例访问序数为SecondaryOwners2元素。换句话说,这是列表的第三元素。

SecondaryOwners[2]

别名

QLDB支持开放内容和架构。因此,当您访问语句中的特定字段时,确保获得预期结果的最佳方法是使用别名。例如,如果您未指定显式别名,则系统会为您的 FROM 源生成一个隐式别名。

SELECT VIN FROM Vehicle --is rewritten to SELECT Vehicle.VIN FROM Vehicle AS Vehicle

但是字段名冲突的结果不可预测。如果文档中的嵌套结构中存在另一个名为VIN的字段,则此查询返回的VIN值可能会让您感到惊讶。作为最佳实践标准,请改写以下语句。此查询声明 vVehicle 表的别名。AS 关键字是可选的。

SELECT v.VIN FROM Vehicle [ AS ] v

当路径进入文档中嵌套集合时,别名特别有用。例如,以下语句声明 oVehicleRegistration.Owners覆盖集合的别名。

SELECT o.SecondaryOwners FROM VehicleRegistration AS r, @r.Owners AS o

此处的 @ 字符在技术上是可选的。但它明确表示你想在里面放置一个Owners结构VehicleRegistration,而不是一个名为不同的集合Owners(如有)。

PartiQL 规范

有关 PartiQL 查询语言的更多信息,请参阅 PartiQL 规范。