GraphQL API

GraphQL API

在前面的章节讲到了使用GraphQL 进行实体的定义。

GraphQL 是一种用于API查询的语言,对 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据。因而可以用于描述数据实体,也可以用于请求想要的数据,得到结果。子图中的数据实体就是使用 GraphQL 接口定义语言(IDL)来描述和定义。

本节来说明如何在HyperGraph 中使用GraphQL查询数据。

查询

在子图 schema.graphql 中,定义了称为实体的类型。对于每种实体类型,将在顶层查询类型上生成一个实体和实体关联的字段。

例子

查询您在实体定义文件中定义的单个Token实体:

{

token(id: "1") {

id

owner

}}

注意:查询单个实体时,id字段是必填字段,并且必须是字符串,一般是地址或者Hash等具有唯一标识作用的值。

查询所有Token实体:

tokens {

id

owner

}}

排序

查询集合时,可以使用orderBy参数按特定属性进行排序。另外,orderDirection可用于指定排序方向,升序表示升序,降序表示降序。

例子

{

tokens(orderBy: price, orderDirection: asc) {

id

owner

}}

分页

查询集合时,可以使用第一个参数从集合的开头进行分页。值得注意的是,默认排序顺序是按ID升序字母和数字顺序排序,而不是按创建时间。

此外,skip参数可用于跳过实体和分页。例如 first:100 显示前100个实体,first:100,skip:100 显示以第100个开始的下100个实体。这跟SQL查询中的 Limit start, number 很像。

查询应避免使用非常大的skip值,因为它们通常速度会很慢。对于检索大量数据,最好根据上一个示例中所示的属性来对实体进行分页。

例子

查询前10个Token:

tokens(first: 10) {

id

owner

}}

为了查询集合中间的一组实体,可以将skip参数与first参数结合使用,以从集合的开头开始跳过指定数量的实体。

例子

查询10个Token实体,从集合开始偏移10个位置:

tokens(first: 10, skip: 10) {

id

owner

}}

例子

如果需要检索大量实体,则将查询基于属性并按该属性进行过滤会更有效率。例如,使用以下查询检索大量Token实体的数据:

{

query manyTokens($lastID: String) {

tokens(first: 1000, where: { id_gt: $lastID }) {

id

owner

}

}}

第一次,它将发送带有 lastID =“” 的查询,并且对于后续请求,会将lastID 设置为上一个请求中最后一个实体的id属性。与使用增加的skip值相比,此方法的性能要好得多。

筛选

您可以在查询中使用where参数来筛选不同的属性。您可以过滤where参数中的多个值,也就是说在where中设置多个条件。

例子

查询失败的 challenge:

{

challenges(where: { outcome: "failed" }) {

challenger

outcome

application {

id

}

}}

您可以使用诸如_gt,_lte之类的后缀进行值比较:

例子

{

applications(where: { deposit_gt: "10000000000" }) {

id

whitelisted

deposit

}}

参数后缀的完整列表:

_not

_gt

_lt

_gte

_lte

_in

_not_in

_contains

_not_contains

_starts_with

_ends_with

_not_starts_with

_not_ends_with

请注意,某些后缀仅适用于特定类型。例如,布尔仅支持_not,_in和_not_in。

时间遍历查询

您不仅可以查询最新区块中实体的状态(默认情况下是查最新块),还可以查询过去的任意区块的状态。通过在查询的顶层字段中包含block参数,可以通过其块号或其块哈希来指定进行查询的块。

这样的查询结果不会随时间变化,即,无论执行什么时候,在特定的过去的块中查询都将返回相同的结果,但有一个例外,如果您在非常靠近以太坊开始的块中进行查询,如果该区块不在主链上并且链被重组,结果可能会改变。一旦一个块可以被认为是最终确认的,查询的结果将不会改变。

例子

{

challenges(block: { number: 8000000 }) {

challenger

outcome

application {

id

}

}}

该查询将返回challenge实体及其关联的应用程序实体,因为它们在8,000,000块后直接存在。

例子

{

challenges(block: { hash: "0x5a0b54d5dc17e0aadc383d2db43b0a0d3e029c4c" }) {

challenger

outcome

application {

id

}

}}

该查询将返回challenge实体及其关联的应用程序实体,因为它们是在使用给定哈希所对应的块之后直接存在的。

Last updated