首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >错误:服务帐户没有bigquery.jobs.create权限

错误:服务帐户没有bigquery.jobs.create权限
EN

Stack Overflow用户
提问于 2017-11-29 06:54:45
回答 1查看 1.2K关注 0票数 1

我创建了一个具有角色大查询管理的服务帐户,我使用的是大查询PHP。请告诉我是否需要其他许可?

它给出了一个错误,指出:

服务帐户没有bigquery.jobs.create权限。

我想在bigquery上运行一个查询。请帮帮忙。

以下是我的代码:

代码语言:javascript
运行
复制
     $service = new Google_Service_Bigquery($client);


    $query = new Google_Service_Bigquery_QueryRequest($client);
      $query->setQuery('SELECT * FROM [xxx:xxx.xxs] LIMIT 1000;');

      $jobs = $service->jobs;
      $response = $jobs->query($project_id, $query);

      // Do something with the BigQuery API $response data
      print_r($response)

;
EN

回答 1

Stack Overflow用户

发布于 2019-11-15 00:48:31

我在使用用于nodejs的BQ库时遇到了这个问题。

似乎通过CLI将其签名到用户/服务帐户并不总是足够的。我的服务帐户经过身份验证,并在GCP中具有正确的权限,但我仍然获得了service account does not have bigquery.jobs.create permission.

我可以通过使用客户端库方法添加相同的服务帐户详细信息来修复这个问题。我用的是https://googleapis.dev/nodejs/bigquery/latest/BigQuery.html

在nodejs的例子中,我只需添加

代码语言:javascript
运行
复制
// Imports BigQuery library
const {BigQuery} = require('@google-cloud/bigquery');
// Create BQ Options - this object is what fixed the issue
const bqOptions = {};
bqOptions.projectId = '*your-project-name*';
bqOptions.keyFilename = '*Path-to-service-account-private-key*';
// Creates BQ client
const bq = new BigQuery(bqOptions);

我知道您正在使用PHP库,但我认为PHP等效程序也会同样工作。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47546763

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档