Package bigquery
Overview ▹
Index ▹
Constants
const Scope = "https://www.googleapis.com/auth/bigquery"
type Client ¶
Client may be used to perform BigQuery operations.
type Client struct {
// contains filtered or unexported fields
}
func NewClient ¶
func NewClient(ctx context.Context, projectID string, opts ...option.ClientOption) (*Client, error)
NewClient constructs a new Client which can perform BigQuery operations. Operations performed via the client are billed to the specified GCP project.
▹ Example
func (*Client) Close ¶
func (c *Client) Close() error
Close closes any resources held by the client. Close should be called when the client is no longer needed. It need not be called at program exit.
func (*Client) Dataset ¶
func (c *Client) Dataset(id string) *Dataset
Dataset creates a handle to a BigQuery dataset in the client's project.
▹ Example
func (*Client) DatasetInProject ¶
func (c *Client) DatasetInProject(projectID, datasetID string) *Dataset
DatasetInProject creates a handle to a BigQuery dataset in the specified project.
▹ Example
func (*Client) Datasets ¶
func (c *Client) Datasets(ctx context.Context) *DatasetIterator
Datasets returns an iterator over the datasets in the Client's project.
▹ Example
func (*Client) DatasetsInProject ¶
func (c *Client) DatasetsInProject(ctx context.Context, projectID string) *DatasetIterator
DatasetsInProject returns an iterator over the datasets in the provided project.
▹ Example
func (*Client) JobFromID ¶
func (c *Client) JobFromID(ctx context.Context, id string) (*Job, error)
JobFromID creates a Job which refers to an existing BigQuery job. The job need not have been created by this package. For example, the job may have been created in the BigQuery console.
▹ Example
func (*Client) Query ¶
func (c *Client) Query(q string) *Query
Query creates a query with string q. The returned Query may optionally be further configured before its Run method is called.
▹ Example
▹ Example (Parameters)
type Compression ¶
Compression is the type of compression to apply when writing data to Google Cloud Storage.
type Compression string
const ( None Compression = "NONE" Gzip Compression = "GZIP" )
type Copier ¶
A Copier copies data into a BigQuery table from one or more BigQuery tables.
type Copier struct {
CopyConfig
// contains filtered or unexported fields
}
func (*Copier) Run ¶
func (c *Copier) Run(ctx context.Context) (*Job, error)
Run initiates a copy job.
type CopyConfig ¶
CopyConfig holds the configuration for a copy job.
type CopyConfig struct { // JobID is the ID to use for the copy job. If unset, a job ID will be automatically created. JobID string // Srcs are the tables from which data will be copied. Srcs []*Table // Dst is the table into which the data will be copied. Dst *Table // CreateDisposition specifies the circumstances under which the destination table will be created. // The default is CreateIfNeeded. CreateDisposition TableCreateDisposition // WriteDisposition specifies how existing data in the destination table is treated. // The default is WriteAppend. WriteDisposition TableWriteDisposition }
type CreateTableOption ¶
A CreateTableOption is an optional argument to CreateTable.
type CreateTableOption interface {
// contains filtered or unexported methods
}
func TableExpiration ¶
func TableExpiration(exp time.Time) CreateTableOption
TableExpiration returns a CreateTableOption that will cause the created table to be deleted after the expiration time.
func UseStandardSQL ¶
func UseStandardSQL() CreateTableOption
UseStandardSQL returns a CreateTableOption to set the table to use standard SQL. The default setting is false (using legacy SQL).
func ViewQuery ¶
func ViewQuery(query string) CreateTableOption
ViewQuery returns a CreateTableOption that causes the created table to be a virtual table defined by the supplied query. For more information see: https://cloud.google.com/bigquery/querying-data#views
type DataFormat ¶
DataFormat describes the format of BigQuery table data.
type DataFormat string
Constants describing the format of BigQuery table data.
const ( CSV DataFormat = "CSV" Avro DataFormat = "AVRO" JSON DataFormat = "NEWLINE_DELIMITED_JSON" DatastoreBackup DataFormat = "DATASTORE_BACKUP" )
type Dataset ¶
Dataset is a reference to a BigQuery dataset.
type Dataset struct {
ProjectID string
DatasetID string
// contains filtered or unexported fields
}
func (*Dataset) Create ¶
func (d *Dataset) Create(ctx context.Context) error
Create creates a dataset in the BigQuery service. An error will be returned if the dataset already exists.
▹ Example
func (*Dataset) Delete ¶
func (d *Dataset) Delete(ctx context.Context) error
Delete deletes the dataset.
▹ Example
func (*Dataset) Metadata ¶
func (d *Dataset) Metadata(ctx context.Context) (*DatasetMetadata, error)
Metadata fetches the metadata for the dataset.
▹ Example
func (*Dataset) Table ¶
func (d *Dataset) Table(tableID string) *Table
Table creates a handle to a BigQuery table in the dataset. To determine if a table exists, call Table.Metadata. If the table does not already exist, use Table.Create to create it.
▹ Example
func (*Dataset) Tables ¶
func (d *Dataset) Tables(ctx context.Context) *TableIterator
Tables returns an iterator over the tables in the Dataset.
▹ Example
type DatasetIterator ¶
DatasetIterator iterates over the datasets in a project.
type DatasetIterator struct { // ListHidden causes hidden datasets to be listed when set to true. ListHidden bool // Filter restricts the datasets returned by label. The filter syntax is described in // https://cloud.google.com/bigquery/docs/labeling-datasets#filtering_datasets_using_labels Filter string // contains filtered or unexported fields }
func (*DatasetIterator) Next ¶
func (it *DatasetIterator) Next() (*Dataset, error)
▹ Example
func (*DatasetIterator) PageInfo ¶
func (it *DatasetIterator) PageInfo() *iterator.PageInfo
PageInfo supports pagination. See the google.golang.org/api/iterator package for details.
type DatasetMetadata ¶
type DatasetMetadata struct { CreationTime time.Time LastModifiedTime time.Time // When the dataset or any of its tables were modified. DefaultTableExpiration time.Duration Description string // The user-friendly description of this table. Name string // The user-friendly name for this table. ID string Location string // The geo location of the dataset. Labels map[string]string // User-provided labels. }
type Encoding ¶
Encoding specifies the character encoding of data to be loaded into BigQuery. See https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.encoding for more details about how this is used.
type Encoding string
const ( UTF_8 Encoding = "UTF-8" ISO_8859_1 Encoding = "ISO-8859-1" )
type Error ¶
An Error contains detailed information about a failed bigquery operation.
type Error struct {
// Mirrors bq.ErrorProto, but drops DebugInfo
Location, Message, Reason string
}
func (Error) Error ¶
func (e Error) Error() string
type ExplainQueryStage ¶
ExplainQueryStage describes one stage of a query.
type ExplainQueryStage struct { // Relative amount of the total time the average shard spent on CPU-bound tasks. ComputeRatioAvg float64 // Relative amount of the total time the slowest shard spent on CPU-bound tasks. ComputeRatioMax float64 // Unique ID for stage within plan. ID int64 // Human-readable name for stage. Name string // Relative amount of the total time the average shard spent reading input. ReadRatioAvg float64 // Relative amount of the total time the slowest shard spent reading input. ReadRatioMax float64 // Number of records read into the stage. RecordsRead int64 // Number of records written by the stage. RecordsWritten int64 // Current status for the stage. Status string // List of operations within the stage in dependency order (approximately // chronological). Steps []*ExplainQueryStep // Relative amount of the total time the average shard spent waiting to be scheduled. WaitRatioAvg float64 // Relative amount of the total time the slowest shard spent waiting to be scheduled. WaitRatioMax float64 // Relative amount of the total time the average shard spent on writing output. WriteRatioAvg float64 // Relative amount of the total time the slowest shard spent on writing output. WriteRatioMax float64 }
type ExplainQueryStep ¶
ExplainQueryStep describes one step of a query stage.
type ExplainQueryStep struct { // Machine-readable operation type. Kind string // Human-readable stage descriptions. Substeps []string }
type ExternalData ¶
ExternalData is a table which is stored outside of BigQuery. It is implemented by GCSReference.
type ExternalData interface {
// contains filtered or unexported methods
}
type ExtractConfig ¶
ExtractConfig holds the configuration for an extract job.
type ExtractConfig struct { // JobID is the ID to use for the extract job. If empty, a job ID will be automatically created. JobID string // Src is the table from which data will be extracted. Src *Table // Dst is the destination into which the data will be extracted. Dst *GCSReference // DisableHeader disables the printing of a header row in exported data. DisableHeader bool }
type ExtractStatistics ¶
ExtractStatistics contains statistics about an extract job.
type ExtractStatistics struct { // The number of files per destination URI or URI pattern specified in the // extract configuration. These values will be in the same order as the // URIs specified in the 'destinationUris' field. DestinationURIFileCounts []int64 }
type Extractor ¶
An Extractor extracts data from a BigQuery table into Google Cloud Storage.
type Extractor struct {
ExtractConfig
// contains filtered or unexported fields
}
func (*Extractor) Run ¶
func (e *Extractor) Run(ctx context.Context) (*Job, error)
Run initiates an extract job.
type FieldSchema ¶
type FieldSchema struct { // The field name. // Must contain only letters (a-z, A-Z), numbers (0-9), or underscores (_), // and must start with a letter or underscore. // The maximum length is 128 characters. Name string // A description of the field. The maximum length is 16,384 characters. Description string // Whether the field may contain multiple values. Repeated bool // Whether the field is required. Ignored if Repeated is true. Required bool // The field data type. If Type is Record, then this field contains a nested schema, // which is described by Schema. Type FieldType // Describes the nested schema if Type is set to Record. Schema Schema }
type FieldType ¶
type FieldType string
const ( StringFieldType FieldType = "STRING" BytesFieldType FieldType = "BYTES" IntegerFieldType FieldType = "INTEGER" FloatFieldType FieldType = "FLOAT" BooleanFieldType FieldType = "BOOLEAN" TimestampFieldType FieldType = "TIMESTAMP" RecordFieldType FieldType = "RECORD" DateFieldType FieldType = "DATE" TimeFieldType FieldType = "TIME" DateTimeFieldType FieldType = "DATETIME" )
type FileConfig ¶
FileConfig contains configuration options that pertain to files, typically text files that require interpretation to be used as a BigQuery table. A file may live in Google Cloud Storage (see GCSReference), or it may be loaded into a table via the Table.LoaderFromReader.
type FileConfig struct { // SourceFormat is the format of the GCS data to be read. // Allowed values are: CSV, Avro, JSON, DatastoreBackup. The default is CSV. SourceFormat DataFormat // FieldDelimiter is the separator for fields in a CSV file, used when // reading or exporting data. The default is ",". FieldDelimiter string // The number of rows at the top of a CSV file that BigQuery will skip when // reading data. SkipLeadingRows int64 // AllowJaggedRows causes missing trailing optional columns to be tolerated // when reading CSV data. Missing values are treated as nulls. AllowJaggedRows bool // AllowQuotedNewlines sets whether quoted data sections containing // newlines are allowed when reading CSV data. AllowQuotedNewlines bool // Indicates if we should automatically infer the options and // schema for CSV and JSON sources. AutoDetect bool // Encoding is the character encoding of data to be read. Encoding Encoding // MaxBadRecords is the maximum number of bad records that will be ignored // when reading data. MaxBadRecords int64 // IgnoreUnknownValues causes values not matching the schema to be // tolerated. Unknown values are ignored. For CSV this ignores extra values // at the end of a line. For JSON this ignores named values that do not // match any column name. If this field is not set, records containing // unknown values are treated as bad records. The MaxBadRecords field can // be used to customize how bad records are handled. IgnoreUnknownValues bool // Schema describes the data. It is required when reading CSV or JSON data, // unless the data is being loaded into a table that already exists. Schema Schema // Quote is the value used to quote data sections in a CSV file. The // default quotation character is the double quote ("), which is used if // both Quote and ForceZeroQuote are unset. // To specify that no character should be interpreted as a quotation // character, set ForceZeroQuote to true. // Only used when reading data. Quote string ForceZeroQuote bool }
type GCSReference ¶
GCSReference is a reference to one or more Google Cloud Storage objects, which together constitute an input or output to a BigQuery operation.
type GCSReference struct { FileConfig // DestinationFormat is the format to use when writing exported files. // Allowed values are: CSV, Avro, JSON. The default is CSV. // CSV is not supported for tables with nested or repeated fields. DestinationFormat DataFormat // Compression specifies the type of compression to apply when writing data // to Google Cloud Storage, or using this GCSReference as an ExternalData // source with CSV or JSON SourceFormat. Default is None. Compression Compression // contains filtered or unexported fields }
func NewGCSReference ¶
func NewGCSReference(uri ...string) *GCSReference
NewGCSReference constructs a reference to one or more Google Cloud Storage objects, which together constitute a data source or destination. In the simple case, a single URI in the form gs://bucket/object may refer to a single GCS object. Data may also be split into mutiple files, if multiple URIs or URIs containing wildcards are provided. Each URI may contain one '*' wildcard character, which (if present) must come after the bucket name. For more information about the treatment of wildcards and multiple URIs, see https://cloud.google.com/bigquery/exporting-data-from-bigquery#exportingmultiple
▹ Example
type Job ¶
A Job represents an operation which has been submitted to BigQuery for processing.
type Job struct {
// contains filtered or unexported fields
}
func (*Job) Cancel ¶
func (j *Job) Cancel(ctx context.Context) error
Cancel requests that a job be cancelled. This method returns without waiting for cancellation to take effect. To check whether the job has terminated, use Job.Status. Cancelled jobs may still incur costs.
func (*Job) ID ¶
func (j *Job) ID() string
func (*Job) Read ¶
func (j *Job) Read(ctx context.Context) (*RowIterator, error)
Read fetches the results of a query job. If j is not a query job, Read returns an error.
▹ Example
func (*Job) Status ¶
func (j *Job) Status(ctx context.Context) (*JobStatus, error)
Status returns the current status of the job. It fails if the Status could not be determined.
func (*Job) Wait ¶
func (j *Job) Wait(ctx context.Context) (*JobStatus, error)
Wait blocks until the job or the context is done. It returns the final status of the job. If an error occurs while retrieving the status, Wait returns that error. But Wait returns nil if the status was retrieved successfully, even if status.Err() != nil. So callers must check both errors. See the example.
▹ Example
type JobStatistics ¶
JobStatistics contains statistics about a job.
type JobStatistics struct { CreationTime time.Time StartTime time.Time EndTime time.Time TotalBytesProcessed int64 Details Statistics }
type JobStatus ¶
JobStatus contains the current State of a job, and errors encountered while processing that job.
type JobStatus struct { State State // All errors encountered during the running of the job. // Not all Errors are fatal, so errors here do not necessarily mean that the job has completed or was unsuccessful. Errors []*Error // Statistics about the job. Statistics *JobStatistics // contains filtered or unexported fields }
func (*JobStatus) Done ¶
func (s *JobStatus) Done() bool
Done reports whether the job has completed. After Done returns true, the Err method will return an error if the job completed unsuccesfully.
func (*JobStatus) Err ¶
func (s *JobStatus) Err() error
Err returns the error that caused the job to complete unsuccesfully (if any).
type LoadConfig ¶
LoadConfig holds the configuration for a load job.
type LoadConfig struct { // JobID is the ID to use for the load job. If unset, a job ID will be automatically created. JobID string // Src is the source from which data will be loaded. Src LoadSource // Dst is the table into which the data will be loaded. Dst *Table // CreateDisposition specifies the circumstances under which the destination table will be created. // The default is CreateIfNeeded. CreateDisposition TableCreateDisposition // WriteDisposition specifies how existing data in the destination table is treated. // The default is WriteAppend. WriteDisposition TableWriteDisposition }
type LoadSource ¶
A LoadSource represents a source of data that can be loaded into a BigQuery table.
This package defines two LoadSources: GCSReference, for Google Cloud Storage objects, and ReaderSource, for data read from an io.Reader.
type LoadSource interface {
// contains filtered or unexported methods
}
type LoadStatistics ¶
LoadStatistics contains statistics about a load job.
type LoadStatistics struct { // The number of bytes of source data in a load job. InputFileBytes int64 // The number of source files in a load job. InputFiles int64 // Size of the loaded data in bytes. Note that while a load job is in the // running state, this value may change. OutputBytes int64 // The number of rows imported in a load job. Note that while an import job is // in the running state, this value may change. OutputRows int64 }
type Loader ¶
A Loader loads data from Google Cloud Storage into a BigQuery table.
type Loader struct {
LoadConfig
// contains filtered or unexported fields
}
func (*Loader) Run ¶
func (l *Loader) Run(ctx context.Context) (*Job, error)
Run initiates a load job.
type MultiError ¶
A MultiError contains multiple related errors.
type MultiError []error
func (MultiError) Error ¶
func (m MultiError) Error() string
type PutMultiError ¶
PutMultiError contains an error for each row which was not successfully inserted into a BigQuery table.
type PutMultiError []RowInsertionError
func (PutMultiError) Error ¶
func (pme PutMultiError) Error() string
type Query ¶
A Query queries data from a BigQuery table. Use Client.Query to create a Query.
type Query struct {
QueryConfig
// contains filtered or unexported fields
}
func (*Query) Read ¶
func (q *Query) Read(ctx context.Context) (*RowIterator, error)
Read submits a query for execution and returns the results via a RowIterator. It is a shorthand for Query.Run followed by Job.Read.
▹ Example
func (*Query) Run ¶
func (q *Query) Run(ctx context.Context) (*Job, error)
Run initiates a query job.
type QueryConfig ¶
QueryConfig holds the configuration for a query job.
type QueryConfig struct { // JobID is the ID to use for the query job. If this field is empty, a job ID // will be automatically created. JobID string // Dst is the table into which the results of the query will be written. // If this field is nil, a temporary table will be created. Dst *Table // The query to execute. See https://cloud.google.com/bigquery/query-reference for details. Q string // DefaultProjectID and DefaultDatasetID specify the dataset to use for unqualified table names in the query. // If DefaultProjectID is set, DefaultDatasetID must also be set. DefaultProjectID string DefaultDatasetID string // TableDefinitions describes data sources outside of BigQuery. // The map keys may be used as table names in the query string. TableDefinitions map[string]ExternalData // CreateDisposition specifies the circumstances under which the destination table will be created. // The default is CreateIfNeeded. CreateDisposition TableCreateDisposition // WriteDisposition specifies how existing data in the destination table is treated. // The default is WriteEmpty. WriteDisposition TableWriteDisposition // DisableQueryCache prevents results being fetched from the query cache. // If this field is false, results are fetched from the cache if they are available. // The query cache is a best-effort cache that is flushed whenever tables in the query are modified. // Cached results are only available when TableID is unspecified in the query's destination Table. // For more information, see https://cloud.google.com/bigquery/querying-data#querycaching DisableQueryCache bool // DisableFlattenedResults prevents results being flattened. // If this field is false, results from nested and repeated fields are flattened. // DisableFlattenedResults implies AllowLargeResults // For more information, see https://cloud.google.com/bigquery/docs/data#nested DisableFlattenedResults bool // AllowLargeResults allows the query to produce arbitrarily large result tables. // The destination must be a table. // When using this option, queries will take longer to execute, even if the result set is small. // For additional limitations, see https://cloud.google.com/bigquery/querying-data#largequeryresults AllowLargeResults bool // Priority specifies the priority with which to schedule the query. // The default priority is InteractivePriority. // For more information, see https://cloud.google.com/bigquery/querying-data#batchqueries Priority QueryPriority // MaxBillingTier sets the maximum billing tier for a Query. // Queries that have resource usage beyond this tier will fail (without // incurring a charge). If this field is zero, the project default will be used. MaxBillingTier int // MaxBytesBilled limits the number of bytes billed for // this job. Queries that would exceed this limit will fail (without incurring // a charge). // If this field is less than 1, the project default will be // used. MaxBytesBilled int64 // UseStandardSQL causes the query to use standard SQL. // The default is false (using legacy SQL). UseStandardSQL bool // Parameters is a list of query parameters. The presence of parameters // implies the use of standard SQL. // If the query uses positional syntax ("?"), then no parameter may have a name. // If the query uses named syntax ("@p"), then all parameters must have names. // It is illegal to mix positional and named syntax. Parameters []QueryParameter }
type QueryParameter ¶
A QueryParameter is a parameter to a query.
type QueryParameter struct { // Name is used for named parameter mode. // It must match the name in the query case-insensitively. Name string // Value is the value of the parameter. // The following Go types are supported, with their corresponding // Bigquery types: // int, int8, int16, int32, int64, uint8, uint16, uint32: INT64 // Note that uint, uint64 and uintptr are not supported, because // they may contain values that cannot fit into a 64-bit signed integer. // float32, float64: FLOAT64 // bool: BOOL // string: STRING // []byte: BYTES // time.Time: TIMESTAMP // Arrays and slices of the above. // Structs of the above. Only the exported fields are used. Value interface{} }
type QueryPriority ¶
QueryPriority specifies a priority with which a query is to be executed.
type QueryPriority string
const ( BatchPriority QueryPriority = "BATCH" InteractivePriority QueryPriority = "INTERACTIVE" )
type QueryStatistics ¶
QueryStatistics contains statistics about a query job.
type QueryStatistics struct { // Billing tier for the job. BillingTier int64 // Whether the query result was fetched from the query cache. CacheHit bool // The type of query statement, if valid. StatementType string // Total bytes billed for the job. TotalBytesBilled int64 // Total bytes processed for the job. TotalBytesProcessed int64 // Describes execution plan for the query. QueryPlan []*ExplainQueryStage // The number of rows affected by a DML statement. Present only for DML // statements INSERT, UPDATE or DELETE. NumDMLAffectedRows int64 // ReferencedTables: [Output-only, Experimental] Referenced tables for // the job. Queries that reference more than 50 tables will not have a // complete list. ReferencedTables []*Table // The schema of the results. Present only for successful dry run of // non-legacy SQL queries. Schema Schema // Standard SQL: list of undeclared query parameter names detected during a // dry run validation. UndeclaredQueryParameterNames []string }
type ReaderSource ¶
A ReaderSource is a source for a load operation that gets data from an io.Reader.
type ReaderSource struct {
FileConfig
// contains filtered or unexported fields
}
func NewReaderSource ¶
func NewReaderSource(r io.Reader) *ReaderSource
NewReaderSource creates a ReaderSource from an io.Reader. You may optionally configure properties on the ReaderSource that describe the data being read, before passing it to Table.LoaderFrom.
type RowInsertionError ¶
RowInsertionError contains all errors that occurred when attempting to insert a row.
type RowInsertionError struct { InsertID string // The InsertID associated with the affected row. RowIndex int // The 0-based index of the affected row in the batch of rows being inserted. Errors MultiError }
func (*RowInsertionError) Error ¶
func (e *RowInsertionError) Error() string
type RowIterator ¶
A RowIterator provides access to the result of a BigQuery lookup.
type RowIterator struct { // StartIndex can be set before the first call to Next. If PageInfo().Token // is also set, StartIndex is ignored. StartIndex uint64 // contains filtered or unexported fields }
func (*RowIterator) Next ¶
func (it *RowIterator) Next(dst interface{}) error
Next loads the next row into dst. Its return value is iterator.Done if there are no more results. Once Next returns iterator.Done, all subsequent calls will return iterator.Done.
dst may implement ValueLoader, or may be a *[]Value, *map[string]Value, or struct pointer.
If dst is a *[]Value, it will be set to to new []Value whose i'th element will be populated with the i'th column of the row.
If dst is a *map[string]Value, a new map will be created if dst is nil. Then for each schema column name, the map key of that name will be set to the column's value.
If dst is pointer to a struct, each column in the schema will be matched with an exported field of the struct that has the same name, ignoring case. Unmatched schema columns and struct fields will be ignored.
Each BigQuery column type corresponds to one or more Go types; a matching struct field must be of the correct type. The correspondences are:
STRING string BOOL bool INTEGER int, int8, int16, int32, int64, uint8, uint16, uint32 FLOAT float32, float64 BYTES []byte TIMESTAMP time.Time DATE civil.Date TIME civil.Time DATETIME civil.DateTime
A repeated field corresponds to a slice or array of the element type. A RECORD type (nested schema) corresponds to a nested struct or struct pointer. All calls to Next on the same iterator must use the same struct type.
It is an error to attempt to read a BigQuery NULL value into a struct field. If your table contains NULLs, use a *[]Value or *map[string]Value.
▹ Example
▹ Example (Struct)
func (*RowIterator) PageInfo ¶
func (it *RowIterator) PageInfo() *iterator.PageInfo
PageInfo supports pagination. See the google.golang.org/api/iterator package for details.
type Schema ¶
Schema describes the fields in a table or query result.
type Schema []*FieldSchema
func InferSchema ¶
func InferSchema(st interface{}) (Schema, error)
InferSchema tries to derive a BigQuery schema from the supplied struct value. NOTE: All fields in the returned Schema are configured to be required, unless the corresponding field in the supplied struct is a slice or array.
It is considered an error if the struct (including nested structs) contains any exported fields that are pointers or one of the following types: uint, uint64, uintptr, map, interface, complex64, complex128, func, chan. In these cases, an error will be returned. Future versions may handle these cases without error.
Recursively defined structs are also disallowed.
▹ Example
type State ¶
State is one of a sequence of states that a Job progresses through as it is processed.
type State int
const ( Pending State = iota Running Done )
type Statistics ¶
Statistics is one of ExtractStatistics, LoadStatistics or QueryStatistics.
type Statistics interface {
// contains filtered or unexported methods
}
type StreamingBuffer ¶
StreamingBuffer holds information about the streaming buffer.
type StreamingBuffer struct { // A lower-bound estimate of the number of bytes currently in the streaming // buffer. EstimatedBytes uint64 // A lower-bound estimate of the number of rows currently in the streaming // buffer. EstimatedRows uint64 // The time of the oldest entry in the streaming buffer. OldestEntryTime time.Time }
type StructSaver ¶
StructSaver implements ValueSaver for a struct. The struct is converted to a map of values by using the values of struct fields corresponding to schema fields. Additional and missing fields are ignored, as are nested struct pointers that are nil.
type StructSaver struct { // Schema determines what fields of the struct are uploaded. It should // match the table's schema. Schema Schema // If non-empty, BigQuery will use InsertID to de-duplicate insertions // of this row on a best-effort basis. InsertID string // Struct should be a struct or a pointer to a struct. Struct interface{} }
func (*StructSaver) Save ¶
func (ss *StructSaver) Save() (row map[string]Value, insertID string, err error)
Save implements ValueSaver.
type Table ¶
A Table is a reference to a BigQuery table.
type Table struct { // ProjectID, DatasetID and TableID may be omitted if the Table is the destination for a query. // In this case the result will be stored in an ephemeral table. ProjectID string DatasetID string // TableID must contain only letters (a-z, A-Z), numbers (0-9), or underscores (_). // The maximum length is 1,024 characters. TableID string // contains filtered or unexported fields }
func (*Table) CopierFrom ¶
func (t *Table) CopierFrom(srcs ...*Table) *Copier
CopierFrom returns a Copier which can be used to copy data into a BigQuery table from one or more BigQuery tables. The returned Copier may optionally be further configured before its Run method is called.
▹ Example
func (*Table) Create ¶
func (t *Table) Create(ctx context.Context, options ...CreateTableOption) error
Create creates a table in the BigQuery service.
▹ Example
▹ Example (Schema)
func (*Table) Delete ¶
func (t *Table) Delete(ctx context.Context) error
Delete deletes the table.
▹ Example
func (*Table) ExtractorTo ¶
func (t *Table) ExtractorTo(dst *GCSReference) *Extractor
ExtractorTo returns an Extractor which can be used to extract data from a BigQuery table into Google Cloud Storage. The returned Extractor may optionally be further configured before its Run method is called.
▹ Example
func (*Table) FullyQualifiedName ¶
func (t *Table) FullyQualifiedName() string
FullyQualifiedName returns the ID of the table in projectID:datasetID.tableID format.
func (*Table) LoaderFrom ¶
func (t *Table) LoaderFrom(src LoadSource) *Loader
LoaderFrom returns a Loader which can be used to load data into a BigQuery table. The returned Loader may optionally be further configured before its Run method is called.
▹ Example
▹ Example (Reader)
func (*Table) Metadata ¶
func (t *Table) Metadata(ctx context.Context) (*TableMetadata, error)
Metadata fetches the metadata for the table.
▹ Example
func (*Table) Read ¶
func (t *Table) Read(ctx context.Context) *RowIterator
Read fetches the contents of the table.
▹ Example
func (*Table) Update ¶
func (t *Table) Update(ctx context.Context, tm TableMetadataToUpdate) (*TableMetadata, error)
Update modifies specific Table metadata fields.
▹ Example
func (*Table) Uploader ¶
func (t *Table) Uploader() *Uploader
Uploader returns an Uploader that can be used to append rows to t. The returned Uploader may optionally be further configured before its Put method is called.
▹ Example
▹ Example (Options)
type TableCreateDisposition ¶
TableCreateDisposition specifies the circumstances under which destination table will be created. Default is CreateIfNeeded.
type TableCreateDisposition string
const ( // CreateIfNeeded will create the table if it does not already exist. // Tables are created atomically on successful completion of a job. CreateIfNeeded TableCreateDisposition = "CREATE_IF_NEEDED" // CreateNever ensures the table must already exist and will not be // automatically created. CreateNever TableCreateDisposition = "CREATE_NEVER" )
type TableIterator ¶
A TableIterator is an iterator over Tables.
type TableIterator struct {
// contains filtered or unexported fields
}
func (*TableIterator) Next ¶
func (it *TableIterator) Next() (*Table, error)
Next returns the next result. Its second return value is Done if there are no more results. Once Next returns Done, all subsequent calls will return Done.
▹ Example
func (*TableIterator) PageInfo ¶
func (it *TableIterator) PageInfo() *iterator.PageInfo
PageInfo supports pagination. See the google.golang.org/api/iterator package for details.
type TableMetadata ¶
TableMetadata contains information about a BigQuery table.
type TableMetadata struct { Description string // The user-friendly description of this table. Name string // The user-friendly name for this table. Schema Schema View string ID string // An opaque ID uniquely identifying the table. Type TableType // The time when this table expires. If not set, the table will persist // indefinitely. Expired tables will be deleted and their storage reclaimed. ExpirationTime time.Time CreationTime time.Time LastModifiedTime time.Time // The size of the table in bytes. // This does not include data that is being buffered during a streaming insert. NumBytes int64 // The number of rows of data in this table. // This does not include data that is being buffered during a streaming insert. NumRows uint64 // The time-based partitioning settings for this table. TimePartitioning *TimePartitioning // Contains information regarding this table's streaming buffer, if one is // present. This field will be nil if the table is not being streamed to or if // there is no data in the streaming buffer. StreamingBuffer *StreamingBuffer }
type TableMetadataToUpdate ¶
TableMetadataToUpdate is used when updating a table's metadata. Only non-nil fields will be updated.
type TableMetadataToUpdate struct { // Description is the user-friendly description of this table. Description optional.String // Name is the user-friendly name for this table. Name optional.String // Schema is the table's schema. // When updating a schema, you can add columns but not remove them. Schema Schema }
type TableType ¶
TableType is the type of table.
type TableType string
const ( RegularTable TableType = "TABLE" ViewTable TableType = "VIEW" ExternalTable TableType = "EXTERNAL" )
type TableWriteDisposition ¶
TableWriteDisposition specifies how existing data in a destination table is treated. Default is WriteAppend.
type TableWriteDisposition string
const ( // WriteAppend will append to any existing data in the destination table. // Data is appended atomically on successful completion of a job. WriteAppend TableWriteDisposition = "WRITE_APPEND" // WriteTruncate overrides the existing data in the destination table. // Data is overwritten atomically on successful completion of a job. WriteTruncate TableWriteDisposition = "WRITE_TRUNCATE" // WriteEmpty fails writes if the destination table already contains data. WriteEmpty TableWriteDisposition = "WRITE_EMPTY" )
type TimePartitioning ¶
TimePartitioning is a CreateTableOption that can be used to set time-based date partitioning on a table. For more information see: https://cloud.google.com/bigquery/docs/creating-partitioned-tables
type TimePartitioning struct { // (Optional) The amount of time to keep the storage for a partition. // If the duration is empty (0), the data in the partitions do not expire. Expiration time.Duration }
type Uploader ¶
An Uploader does streaming inserts into a BigQuery table. It is safe for concurrent use.
type Uploader struct { // SkipInvalidRows causes rows containing invalid data to be silently // ignored. The default value is false, which causes the entire request to // fail if there is an attempt to insert an invalid row. SkipInvalidRows bool // IgnoreUnknownValues causes values not matching the schema to be ignored. // The default value is false, which causes records containing such values // to be treated as invalid records. IgnoreUnknownValues bool // A TableTemplateSuffix allows Uploaders to create tables automatically. // // Experimental: this option is experimental and may be modified or removed in future versions, // regardless of any other documented package stability guarantees. // // When you specify a suffix, the table you upload data to // will be used as a template for creating a new table, with the same schema, // called <table> + <suffix>. // // More information is available at // https://cloud.google.com/bigquery/streaming-data-into-bigquery#template-tables TableTemplateSuffix string // contains filtered or unexported fields }
func (*Uploader) Put ¶
func (u *Uploader) Put(ctx context.Context, src interface{}) error
Put uploads one or more rows to the BigQuery service.
If src is ValueSaver, then its Save method is called to produce a row for uploading.
If src is a struct or pointer to a struct, then a schema is inferred from it and used to create a StructSaver. The InsertID of the StructSaver will be empty.
If src is a slice of ValueSavers, structs, or struct pointers, then each element of the slice is treated as above, and multiple rows are uploaded.
Put returns a PutMultiError if one or more rows failed to be uploaded. The PutMultiError contains a RowInsertionError for each failed row.
Put will retry on temporary errors (see https://cloud.google.com/bigquery/troubleshooting-errors). This can result in duplicate rows if you do not use insert IDs. Also, if the error persists, the call will run indefinitely. Pass a context with a timeout to prevent hanging calls.
▹ Example
▹ Example (Struct)
▹ Example (StructSaver)
type Value ¶
Value stores the contents of a single cell from a BigQuery result.
type Value interface{}
type ValueLoader ¶
ValueLoader stores a slice of Values representing a result row from a Read operation. See RowIterator.Next for more information.
type ValueLoader interface { Load(v []Value, s Schema) error }
type ValueSaver ¶
A ValueSaver returns a row of data to be inserted into a table.
type ValueSaver interface { // Save returns a row to be inserted into a BigQuery table, represented // as a map from field name to Value. // If insertID is non-empty, BigQuery will use it to de-duplicate // insertions of this row on a best-effort basis. Save() (row map[string]Value, insertID string, err error) }
type ValuesSaver ¶
ValuesSaver implements ValueSaver for a slice of Values.
type ValuesSaver struct { Schema Schema // If non-empty, BigQuery will use InsertID to de-duplicate insertions // of this row on a best-effort basis. InsertID string Row []Value }
func (*ValuesSaver) Save ¶
func (vls *ValuesSaver) Save() (map[string]Value, string, error)
Save implements ValueSaver.