列出项目中的所有连接元数据。
包含此代码示例的文档页面
如需查看上下文中使用的代码示例,请参阅以下文档:
代码示例
Go
在尝试此示例之前,请按照《BigQuery 快速入门:使用客户端库》中的 Go 设置说明进行操作。如需了解详情,请参阅 BigQuery Go API 参考文档。
// The bigquery_connection_quickstart application demonstrates basic usage of the
// BigQuery connection API.
package main
import (
"bytes"
"context"
"flag"
"fmt"
"log"
"time"
connection "cloud.google.com/go/bigquery/connection/apiv1"
"google.golang.org/api/iterator"
connectionpb "google.golang.org/genproto/googleapis/cloud/bigquery/connection/v1"
)
func main() {
// Define two command line flags for controlling the behavior of this quickstart.
projectID := flag.String("project_id", "", "Cloud Project ID, used for session creation.")
location := flag.String("location", "US", "BigQuery location used for interactions.")
// Parse flags and do some minimal validation.
flag.Parse()
if *projectID == "" {
log.Fatal("empty --project_id specified, please provide a valid project ID")
}
if *location == "" {
log.Fatal("empty --location specified, please provide a valid location")
}
ctx := context.Background()
connClient, err := connection.NewClient(ctx)
if err != nil {
log.Fatalf("NewClient: %v", err)
}
defer connClient.Close()
s, err := reportConnections(ctx, connClient, *projectID, *location)
if err != nil {
log.Fatalf("printCapacityCommitments: %v", err)
}
fmt.Println(s)
}
// reportConnections gathers basic information about existing connections in a given project and location.
func reportConnections(ctx context.Context, client *connection.Client, projectID, location string) (string, error) {
var buf bytes.Buffer
fmt.Fprintf(&buf, "Current connections defined in project %s in location %s:\n", projectID, location)
req := &connectionpb.ListConnectionsRequest{
Parent: fmt.Sprintf("projects/%s/locations/%s", projectID, location),
}
totalConnections := 0
it := client.ListConnections(ctx, req)
for {
conn, err := it.Next()
if err == iterator.Done {
break
}
if err != nil {
return "", err
}
fmt.Fprintf(&buf, "\tConnection %s was created %s\n", conn.GetName(), unixMillisToTime(conn.GetCreationTime()).Format(time.RFC822Z))
totalConnections++
}
fmt.Fprintf(&buf, "\n%d connections processed.\n", totalConnections)
return buf.String(), nil
}
// unixMillisToTime converts epoch-millisecond representations used by the API into a time.Time representation.
func unixMillisToTime(m int64) time.Time {
if m == 0 {
return time.Time{}
}
return time.Unix(0, m*1e6)
}
Java
试用此示例之前,请按照《BigQuery 快速入门:使用客户端库》中的 Java 设置说明进行操作。 如需了解详情,请参阅 BigQuery Java API 参考文档。
import com.google.cloud.bigquery.connection.v1.ListConnectionsRequest;
import com.google.cloud.bigquery.connection.v1.LocationName;
import com.google.cloud.bigqueryconnection.v1.ConnectionServiceClient;
import java.io.IOException;
// Sample to demonstrates basic usage of the BigQuery connection API.
public class QuickstartSample {
public static void main(String[] args) throws IOException {
// TODO(developer): Replace these variables before running the sample.
String projectId = "MY_PROJECT_ID";
String location = "MY_LOCATION";
listConnections(projectId, location);
}
public static void listConnections(String projectId, String location) throws IOException {
try (ConnectionServiceClient connectionServiceClient = ConnectionServiceClient.create()) {
LocationName parent = LocationName.of(projectId, location);
int pageSize = 10;
ListConnectionsRequest request =
ListConnectionsRequest.newBuilder()
.setParent(parent.toString())
.setPageSize(pageSize)
.build();
ConnectionServiceClient.ListConnectionsPagedResponse response =
connectionServiceClient.listConnections(request);
// Print the results.
System.out.println("List of connections:");
response
.iterateAll()
.forEach(connection -> System.out.println("Connection Name: " + connection.getName()));
}
}
}
Node.js
在尝试此示例之前,请按照《BigQuery 快速入门:使用客户端库》中的 Node.js 设置说明进行操作。如需了解详情,请参阅 BigQuery Node.js API 参考文档。
// Imports the Google Cloud client library
const {
ConnectionServiceClient,
} = require('@google-cloud/bigquery-connection');
// Creates a client
const client = new ConnectionServiceClient();
// project = 'my-project' // Project to list connections for.
const parent = `projects/${project}/locations/US`;
async function listConnections() {
const [connections] = await client.listConnections({
parent: parent,
});
console.info(`found ${connections.length} connections:`);
console.info(connections);
}
const listConnectionsResponse = listConnections();