首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Google BigQuery中获取数据集名称,包括“公共数据”

如何在Google BigQuery中获取数据集名称,包括“公共数据”
EN

Stack Overflow用户
提问于 2014-06-04 14:00:07
回答 3查看 601关注 0票数 7

我为google BigQuery创建jdbc连接

代码语言:javascript
复制
    Class.forName("net.starschema.clouddb.jdbc.BQDriver");
    conn = DriverManager.getConnection("jdbc:BQDriver:"projectID"?transformQuery=true&user="client ID"&password="client secret");

然后我得到目录名如下

代码语言:javascript
复制
 ResultSet m_resultSet = conn.getMetaData().getCatalogs();
 while (m_resultSet.next())
 {
     System.out.println(m_resultSet.getString(4));
 }

但现在我正在尝试获取数据集的名称。它返回null。

我能得到公共数据的数据集名称吗?怎么做??

EN

回答 3

Stack Overflow用户

发布于 2015-07-16 07:31:55

您可以使用下面的代码获取项目、数据集和表的列表。

要获取公共数据,可以使用下面的代码

代码语言:javascript
复制
var SampleTableList = Service.Tables.List("publicdata", "samples").Execute();

因为公共数据只有一个DataSet (示例),所以我们不能添加新的数据集,这样代码才能正常工作。

修改属性,如ServiceAccountEmail、KeyFile路径和密钥秘密等。

代码语言:javascript
复制
using Google.Apis.Auth.OAuth2;
using System.IO;
using System.Threading;
using Google.Apis.Bigquery.v2;
using Google.Apis.Bigquery.v2.Data;
using System.Data;
using Google.Apis.Services;
using System;
using System.Security.Cryptography.X509Certificates;

namespace GoogleBigQuery
{
    public class Class1
    {
        private static void Main()
        {
            try
            {
                String serviceAccountEmail = "SERVICE ACCOUNT EMAIL";

                var certificate = new X509Certificate2(@"KEY FILE NAME & PATH", "KEY SECRET", X509KeyStorageFlags.Exportable);

                // SYNTAX: var certificate=new X509Certificate2(KEY FILE PATH+NAME (Here it resides in Bin\Debug folder so only name is enough), SECRET KEY, X509KeyStorageFlags.Exportable);

                ServiceAccountCredential credential = new ServiceAccountCredential(
                   new ServiceAccountCredential.Initializer(serviceAccountEmail)
                   {
                       Scopes = new[] { BigqueryService.Scope.Bigquery, BigqueryService.Scope.BigqueryInsertdata, BigqueryService.Scope.CloudPlatform, BigqueryService.Scope.DevstorageFullControl }
                   }.FromCertificate(certificate));

                //  Create and initialize the Bigquery service. Use the Project Name value
                //  from the New Project window for the ApplicationName variable.

                BigqueryService Service = new BigqueryService(new BaseClientService.Initializer()
                {
                    HttpClientInitializer = credential,
                    ApplicationName = "APPLICATION NAME"
                });


                var SampleTableList = Service.Tables.List("publicdata", "samples").Execute();

                var projectList = Service.Projects.List().Execute();

                foreach (var projectDet in projectList.Projects)
                {
                    var DataSetList = Service.Datasets.List(projectDet.Id).Execute();

                    foreach (var DataSetDet in DataSetList.Datasets)
                    {
                        var TablesList = Service.Tables.List(projectDet.Id, DataSetDet.Id).Execute();
                    }
                }

            }
            catch (Exception e)
            {
                Console.WriteLine("Error Occurred: " + e.Message);
            }

            Console.ReadLine();
        }
    }
}
票数 1
EN

Stack Overflow用户

发布于 2015-07-31 16:05:55

看起来这是获取公共数据集列表的最佳来源:http://www.reddit.com/r/bigquery/wiki/datasets

票数 0
EN

Stack Overflow用户

发布于 2016-04-23 05:25:56

我知道如何在公共数据中获取数据集,问题是如何获得包含公共数据的项目列表?- Andrey 17 '15,21:27

以编程方式,用户只能获得他/她已被授予任何项目角色的项目列表:

Can ViewCan EditIs Owner

公共数据通过与All Authenticated Users在数据集级别上共享而变得公开

因此,用户不能列出具有公共数据的项目。

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

https://stackoverflow.com/questions/24039522

复制
相关文章

相似问题

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