bigqueryio

package
v3.0.0-...-7ba4d6b Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 17, 2024 License: Apache-2.0, BSD-3-Clause, MIT Imports: 6 Imported by: 0

Documentation

Overview

Package bigqueryio contains cross-language functionality for using Google Cloud BigQuery (https://cloud.google.com/bigquery). These transforms only work on runners that support cross-language transforms.

Setup

Transforms specified here are cross-language transforms implemented in a different SDK (listed below). During pipeline construction, the Go SDK will need to connect to an expansion service containing information on these transforms in their native SDK. If an expansion service address is not provided, an appropriate expansion service will be automatically started; however this is slower than having a persistent expansion service running.

To use a persistent expansion service, it must be run as a separate process accessible during pipeline construction. The address of that process must be passed to the transforms in this package.

The version of the expansion service should match the version of the Beam SDK being used. For numbered releases of Beam, these expansions services are released to the Maven repository as modules. For development versions of Beam, it is recommended to build and run it from source using Gradle.

Current supported SDKs, including expansion service modules and reference documentation:

Java:

  • Vendored Module: beam-sdks-java-extensions-schemaio-expansion-service
  • Run via Gradle: ./gradlew :sdks:java:extensions:schemaio-expansion-service:runExpansionService
  • Reference Class: org.apache.beam.sdk.io.gcp.bigquery.BigQuerySchemaIOProvider and org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO

Type Conversions

Elements are read from and written to BigQuery by first converting to a Beam schema Row type before converting to BigQuery compatible types. The following table lists all BigQuery types currently supported, and how they convert to Beam schema and Go types.

+----------------------------+------------------+-----------------+
| BigQuery Standard SQL Type | Beam Schema Type |     Go Type     |
+----------------------------+------------------+-----------------+
| BOOLEAN                    | BOOLEAN          | bool            |
| INT64                      | INT64            | int64           |
| FLOAT64                    | DOUBLE           | float64         |
| BYTES                      | BYTES            | []byte          |
| STRING                     | STRING           | string          |
| ARRAY                      | ARRAY            | Special: slice  |
| STRUCT                     | ROW              | Special: struct |
+----------------------------+------------------+-----------------+

Array types are inferred from slice fields. For example, []int64 is equivalent to BigQuery's ARRAY<INT64>. Struct types are inferred from nested structs in Go.

Additionally, BigQuery schema fields can have a mode assigned to specify whether the field is Nullable, Required, or Repeated. In Go, Nullable fields are represented as pointers, whereas Required fields are value types. Repeated fields are represented as slices in Go (and ARRAYS in SQL, as in the table above).

Example of BigQuery fields with modes:

field1 *int64   // Nullable INT64
field2 int64    // Required INT64
field3 []int64  // Repeated INT64

Note On Documentation

This cross-language implementation relies on the behavior of external SDKs. In order to keep documentation up-to-date and consistent, BigQuery functionality will not be described in detail in this package. Instead, references to relevant documentation in other SDKs is included where relevant.

Index

Constants

View Source
const (
	// CreateNever specifies that new tables should not be created when writing to BigQuery.
	CreateNever createDisposition = "Never"

	// CreateIfNeeded specifies that tables should be created when writing to BigQuery, if needed.
	CreateIfNeeded createDisposition = "IfNeeded"
)

Variables

This section is empty.

Functions

func CreateDisposition

func CreateDisposition(disp createDisposition) writeOption

CreateDisposition specifies the write transform's behavior in regards to creating new tables.

For more details see in the Java SDK: org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO.Write.withCreateDisposition

func FromQuery

func FromQuery(query string) readOption

FromQuery is a Read option that specifies a query to use for reading from BigQuery. Uses the BigQuery Standard SQL dialect.

Important: When reading from a query, the schema of any source tables is not used and the read transform cannot detect which elements are Required, therefore every field in the output type will be a pointer (including fields within inner structs).

For more details see in the Java SDK: org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO.Read.fromQuery(java.lang.String)

BUG(https://github.com/apache/beam/issues/21784): Query read outputs currently cannot be named struct types. See link for workaround.

func FromTable

func FromTable(table string) readOption

FromTable is a Read option that specifies which table to read from.

For more details see in the Java SDK: org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO.Read.from(java.lang.String)

func Read

func Read(s beam.Scope, elmT reflect.Type, opts ...readOption) beam.PCollection

Read is a cross-language PTransform which reads from a BigQuery table and returns a PCollection of the given type, which should correspond to the Schema type generated by reading from the table.

Read requires a reflect.Type description of the struct to read from BigQuery. Additionally, either one Table or one Query must be provided via readOptions to define a destination to read from.

Read accepts additional parameters as readOptions. All optional parameters are predefined in this package as functions that return readOption. To set an additional parameter, call the function within Read's function signature.

Example:

expansionAddr := "localhost:1234"
table := "project_id:dataset_id.table_id"
outType := reflect.TypeOf((*Foo)(nil)).Elem()
pcol := bigqueryio.Read(s, outType,
    bigqueryio.FromTable(table),
    bigqueryio.ReadExpansionAddr(expansionAddr))

func ReadExpansionAddr

func ReadExpansionAddr(addr string) readOption

ReadExpansionAddr specifies the address of a persistent expansion service to use for a Read transform. If this is not provided, or if an empty string is provided, the transform will automatically start an appropriate expansion service instead.

func WithQueryLocation

func WithQueryLocation(location string) readOption

WithQueryLocation is a Read option that specifies a BigQuery geographic location where the query job will be executed.

For more details see in the Java SDK: org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO.TypedRead.withQueryLocation

func Write

func Write(s beam.Scope, table string, col beam.PCollection, opts ...writeOption)

Write is a cross-language PTRansform which writes elements from a PCollection to a BigQuery table.

Write requires the ID of a BigQuery table, and an input PCollection. The type of the input PCollection is converted to a Beam schema, so it must have a valid Beam schema definition.

Write accepts additional parameters as writeOptions. All optional parameters are predefined in this package as functions that return writeOption. To set an additional parameter, call the function within Write's function signature.

Example:

expansionAddr := "localhost:1234"
table := "project_id:dataset_id.table_id"
pcol := bigqueryio.Write(s, table, input,
   bigqueryio.CreateDisposition(bigqueryio.CreateIfNeeded),
   bigqueryio.WriteExpansionAddr(expansionAddr))

func WriteExpansionAddr

func WriteExpansionAddr(addr string) writeOption

WriteExpansionAddr specifies the address of a persistent expansion service to use for a Write transform. If this is not provided, or if an empty string is provided, the transform will automatically start an appropriate expansion service instead.

Types

This section is empty.

Notes

Bugs

  • Query read outputs currently cannot be named struct types. See link for workaround.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL