AppSync - 查询在一个日期范围内创建的所有项目?

AppSync - query for all items created within a date range?

我正在尝试查询特定日期范围内的所有项目(具有 AWS DateTime 的 CreatedAt 和 UpdatedAt 字段)。例如,过去 48 小时。

例如,使用此架构:

type Note @model @searchable @auth(rules: [{ allow: owner }]) {
  id: ID!
  note: String
  createdAt: AWSDateTime

我可以使用以下方法搜索日期:

query {
  searchNotes(filter:{createdAt: { matchPhrasePrefix: "2018-12-27"}}) {
    items{
      id
        title
      createdAt
    }
  }
}

returns 所有与 UTC 时间匹配的注释都带有该字符串前缀。

从中,我必须使用 moment.diff() 或其他方法对自己进行排序。

我不确定是否有better/more使用 AppSync 和 GraphQl 按日期和时间执行 searching/filtering 的有效方法?

谢谢。

截至撰写本文时(2019 年 1 月 3 日),最简单的方法是将日期存储为整数(例如自纪元以来的秒数),这将打开 gt, lt, gte, ... 筛选字段自动生成的搜索解析器过滤输入。

另一种解决方案是使用 AWS AppSync 控制台或您自己的 CloudFormation 堆栈编写您自己的解析器。编写自己的解析器时,您可以利用整个 Elasticsearch DSL 来实现各种查询(参见 https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-range-query.html)。要沿着这条路线走下去,您可以将自己的搜索字段添加到架构中的查询类型并编写自定义解析器。

type Query {
  searchNotesByCreatedAt(start: String!, end: String!): NotesConnection
}

然后通过控制台或您自己的 CloudFormation 堆栈,您可以像这样编写一个解析器:

{
  "version": "2017-02-28",
  "operation": "GET",
  "path": "/note-<your-api-id>/doc/_search", // created by amplify
  "params": {
    "body": {
      "sort": [{ "createdAt" : {"order" : "desc"}}],
      "query": {
        "range" : {
            "createdAt" : {
                "gte": $ctx.args.start, 
                "lte": $ctx.args.end
            }
        }
      }
    }
  }
}

您只需要暂时使用控制台或您自己的 CF 堆栈部署此解析器。正在开展工作以允许您从 amplify CLI 中编写自己的解析器。有关这将如何工作的更多信息,请参阅 https://github.com/aws-amplify/amplify-cli/issues/574.

让我知道这是否适合你。

您可以使用此查询来过滤 2 AWSDateTime:

query {
  searchNotes(filter:{createdAt: { between: ["2018-12-27T00:00:00", "2019-01-27T00:00:00"]}}) {
    items{
      id
        title
      createdAt
    }
  }
}