0

我正在尝试使用 google-api-nodejs-client 对我的 Google Cloud 数据存储运行一个简单的查询。我想查询与给定种类匹配的所有实体。当我使用“立即尝试”工具运行此查询时,它工作正常:

Request

POST https://www.googleapis.com/datastore/v1beta2/datasets/healthier-staging/runQuery?key={YOUR_API_KEY}

{
 "query": {
  "kinds": [
   {
    "name": "Subscriber"
   }
  ]
 }
}

Response

200 OK

{
 "batch": {
  "entityResultType": "FULL",
  "entityResults": [
   {
    "entity": {
     "key": {
      "partitionId": {
       "datasetId": "s~healthier-staging"
      },
      "path": [
       {
        "kind": "Subscriber",
        "name": "+1215XXXXXXX"
       }
      ]
     },
     "properties": {
...

我能够使用我的凭据进行身份验证、创建交易等,所以我知道这不是身份验证问题。

这是我试图在 Node 中运行的代码:

this.datastore.runQuery({
    datasetId: 'healthier-staging',
    query: {
        kinds: [{name: 'Subscriber'}]
    },
}, (function(err, result) {
    if (err) {
        console.error(err);
        return;
    }
}).bind(this));

当我尝试使用 Node 模块运行相同的查询时,我收到此错误:

{ [Error: one of fields Query.query and Query.gql_query must be set]
  code: 400,
  errors: 
   [ { domain: 'global',
       reason: 'INVALID_ARGUMENT',
       message: 'one of fields Query.query and Query.gql_query must be set' } ] }

这没有意义,因为我已经指定了query字段。我已经尝试了各种各样的事情:删除datasetId(产生关于需要的错误datasetId),使用gql_query(相同的错误),封装datasetId内部事务并将其传递到内部readOptions,等等。

这是一个错误还是我在做一些愚蠢的事情?

谢谢!

4

1 回答 1

1

我在您的其他 StackOverflow 问题中提到了这一点,但您的请求应包含在资源部分中:

this.datastore.runQuery({
    datasetId: 'healthier-staging',
    resource: {
        query: {
            kinds: [{name: 'Subscriber'}]
        },
    },
}, (function(err, result) {
    if (err) {
        console.error(err);
        return;
    }
}).bind(this));
于 2015-06-29T14:49:07.120 回答