- Resource: Table
- TableSchema
- TableFieldSchema
- FieldElementType
- TimePartitioning
- RangePartitioning
- Clustering
- PartitioningDefinition
- PartitionedColumn
- ViewDefinition
- UserDefinedFunctionResource
- PrivacyPolicy
- AggregationThresholdPolicy
- MaterializedViewDefinition
- MaterializedViewStatus
- ErrorProto
- ExternalDataConfiguration
- FileSetSpecType
- CsvOptions
- JsonOptions
- BigtableOptions
- BigtableColumnFamily
- BigtableColumn
- GoogleSheetsOptions
- HivePartitioningOptions
- DecimalTargetType
- AvroOptions
- JsonExtension
- ParquetOptions
- MapTargetType
- ObjectMetadata
- MetadataCacheMode
- BigLakeConfiguration
- FileFormat
- TableFormat
- Streamingbuffer
- SnapshotDefinition
- CloneDefinition
- TableConstraints
- PrimaryKey
- ForeignKey
- ColumnReference
- ExternalCatalogTableOptions
- StorageDescriptor
- SerDeInfo
- Methods
Resource: Table
JSON representation |
---|
{ "kind": string, "etag": string, "id": string, "selfLink": string, "tableReference": { object ( |
Fields | |
---|---|
kind |
The type of resource ID. |
etag |
Output only. A hash of this resource. |
id |
Output only. An opaque ID uniquely identifying the table. |
self |
Output only. A URL that can be used to access this resource again. |
table |
Required. Reference describing the ID of this table. |
friendly |
Optional. A descriptive name for this table. |
description |
Optional. A user-friendly description of this table. |
labels |
The labels associated with this table. You can use these to organize and group your tables. Label keys and values can be no longer than 63 characters, can only contain lowercase letters, numeric characters, underscores and dashes. International characters are allowed. Label values are optional. Label keys must start with a letter and each label in the list must have a different key. |
schema |
Optional. Describes the schema of this table. |
time |
If specified, configures time-based partitioning for this table. |
range |
If specified, configures range partitioning for this table. |
clustering |
Clustering specification for the table. Must be specified with time-based partitioning, data in the table will be first partitioned and subsequently clustered. |
require |
Optional. If set to true, queries over this table require a partition filter that can be used for partition elimination to be specified. |
num |
Output only. The size of this table in logical bytes, excluding any data in the streaming buffer. |
num |
Output only. The number of logical bytes in the table that are considered "long-term storage". |
num |
Output only. The number of rows of data in this table, excluding any data in the streaming buffer. |
creation |
Output only. The time when this table was created, in milliseconds since the epoch. |
expiration |
Optional. The time when this table expires, in milliseconds since the epoch. If not present, the table will persist indefinitely. Expired tables will be deleted and their storage reclaimed. The defaultTableExpirationMs property of the encapsulating dataset can be used to set a default expirationTime on newly created tables. |
last |
Output only. The time when this table was last modified, in milliseconds since the epoch. |
type |
Output only. Describes the table type. The following values are supported:
The default value is |
view |
Optional. The view definition. |
materialized |
Optional. The materialized view definition. |
materialized |
Output only. The materialized view status. |
external |
Optional. Describes the data format, location, and other properties of a table stored outside of BigQuery. By defining these properties, the data source can then be queried as if it were a standard BigQuery table. |
biglake |
Optional. Specifies the configuration of a BigLake managed table. |
location |
Output only. The geographic location where the table resides. This value is inherited from the dataset. |
streaming |
Output only. Contains information regarding this table's streaming buffer, if one is present. This field will be absent if the table is not being streamed to or if there is no data in the streaming buffer. |
encryption |
Custom encryption configuration (e.g., Cloud KMS keys). |
snapshot |
Output only. Contains information about the snapshot. This value is set via snapshot creation. |
default |
Optional. Defines the default collation specification of new STRING fields in the table. During table creation or update, if a STRING field is added to this table without explicit collation specified, then the table inherits the table default collation. A change to this field affects only fields added afterwards, and does not alter the existing fields. The following values are supported:
|
default |
Optional. Defines the default rounding mode specification of new decimal fields (NUMERIC OR BIGNUMERIC) in the table. During table creation or update, if a decimal field is added to this table without an explicit rounding mode specified, then the field inherits the table default rounding mode. Changing this field doesn't affect existing fields. |
clone |
Output only. Contains information about the clone. This value is set via the clone operation. |
num |
Output only. Number of physical bytes used by time travel storage (deleted or changed data). This data is not kept in real time, and might be delayed by a few seconds to a few minutes. |
num |
Output only. Total number of logical bytes in the table or materialized view. |
num |
Output only. Number of logical bytes that are less than 90 days old. |
num |
Output only. Number of logical bytes that are more than 90 days old. |
num |
Output only. The physical size of this table in bytes. This also includes storage used for time travel. This data is not kept in real time, and might be delayed by a few seconds to a few minutes. |
num |
Output only. Number of physical bytes less than 90 days old. This data is not kept in real time, and might be delayed by a few seconds to a few minutes. |
num |
Output only. Number of physical bytes more than 90 days old. This data is not kept in real time, and might be delayed by a few seconds to a few minutes. |
num |
Output only. The number of partitions present in the table or materialized view. This data is not kept in real time, and might be delayed by a few seconds to a few minutes. |
max |
Optional. The maximum staleness of data that could be returned when the table (or stale MV) is queried. Staleness encoded as a string encoding of sql IntervalValue type. |
table |
Optional. Tables Primary Key and Foreign Key information |
resource |
Optional. The tags attached to this table. Tag keys are globally unique. Tag key is expected to be in the namespaced format, for example "123456789012/environment" where 123456789012 is the ID of the parent organization or project resource for this tag key. Tag value is expected to be the short name, for example "Production". See Tag definitions for more details. |
replicas[] |
Optional. Output only. Table references of all replicas currently active on the table. |
external |
Optional. Options defining open source compatible table. |
partition |
Optional. The partition information for all table formats, including managed partitioned tables, hive partitioned tables, iceberg partitioned, and metastore partitioned tables. This field is only populated for metastore partitioned tables. For other table formats, this is an output only field. |
TableSchema
Schema of a table
JSON representation |
---|
{
"fields": [
{
object ( |
Fields | |
---|---|
fields[] |
Describes the fields in a table. |
TableFieldSchema
A field in TableSchema
JSON representation |
---|
{ "name": string, "type": string, "mode": string, "fields": [ { object ( |
Fields | |
---|---|
name |
Required. The field name. The 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 300 characters. |
type |
Required. The field data type. Possible values include:
Use of RECORD/STRUCT indicates that the field contains a nested schema. |
mode |
Optional. The field mode. Possible values include NULLABLE, REQUIRED and REPEATED. The default value is NULLABLE. |
fields[] |
Optional. Describes the nested schema fields if the type property is set to RECORD. |
description |
Optional. The field description. The maximum length is 1,024 characters. |
policy |
Optional. The policy tags attached to this field, used for field-level access control. If not set, defaults to empty policyTags. |
policy |
A list of policy tag resource names. For example, "projects/1/locations/eu/taxonomies/2/policyTags/3". At most 1 policy tag is currently allowed. |
max |
Optional. Maximum length of values of this field for STRINGS or BYTES. If maxLength is not specified, no maximum length constraint is imposed on this field. If type = "STRING", then maxLength represents the maximum UTF-8 length of strings in this field. If type = "BYTES", then maxLength represents the maximum number of bytes in this field. It is invalid to set this field if type ≠ "STRING" and ≠ "BYTES". |
precision |
Optional. Precision (maximum number of total digits in base 10) and scale (maximum number of digits in the fractional part in base 10) constraints for values of this field for NUMERIC or BIGNUMERIC. It is invalid to set precision or scale if type ≠ "NUMERIC" and ≠ "BIGNUMERIC". If precision and scale are not specified, no value range constraint is imposed on this field insofar as values are permitted by the type. Values of this NUMERIC or BIGNUMERIC field must be in this range when:
Acceptable values for precision and scale if both are specified:
Acceptable values for precision if only precision is specified but not scale (and thus scale is interpreted to be equal to zero):
If scale is specified but not precision, then it is invalid. |
scale |
Optional. See documentation for precision. |
rounding |
Optional. Specifies the rounding mode to be used when storing values of NUMERIC and BIGNUMERIC type. |
collation |
Optional. Field collation can be set only when the type of field is STRING. The following values are supported:
|
default |
Optional. A SQL expression to specify the default value for this field. |
range |
Optional. The subtype of the RANGE, if the type of this field is RANGE. If the type is RANGE, this field is required. Values for the field element type can be the following:
|
FieldElementType
Represents the type of a field element.
JSON representation |
---|
{ "type": string } |
Fields | |
---|---|
type |
Required. The type of a field element. For more information, see |
TimePartitioning
JSON representation |
---|
{ "type": string, "expirationMs": string, "field": string, "requirePartitionFilter": boolean } |
Fields | |
---|---|
type |
Required. The supported types are DAY, HOUR, MONTH, and YEAR, which will generate one partition per day, hour, month, and year, respectively. |
expiration |
Optional. Number of milliseconds for which to keep the storage for a partition. A wrapper is used here because 0 is an invalid value. |
field |
Optional. If not set, the table is partitioned by pseudo column '_PARTITIONTIME'; if set, the table is partitioned by this field. The field must be a top-level TIMESTAMP or DATE field. Its mode must be NULLABLE or REQUIRED. A wrapper is used here because an empty string is an invalid value. |
requirePartitionFilter |
If set to true, queries over this table require a partition filter that can be used for partition elimination to be specified. This field is deprecated; please set the field with the same name on the table itself instead. This field needs a wrapper because we want to output the default value, false, if the user explicitly set it. |
RangePartitioning
JSON representation |
---|
{ "field": string, "range": { "start": string, "end": string, "interval": string } } |
Fields | |
---|---|
field |
Required. The name of the column to partition the table on. It must be a top-level, INT64 column whose mode is NULLABLE or REQUIRED. |
range |
Defines the ranges for range partitioning. |
range. |
Required. The start of range partitioning, inclusive. This field is an INT64 value represented as a string. |
range. |
Required. The end of range partitioning, exclusive. This field is an INT64 value represented as a string. |
range. |
Required. The width of each interval. This field is an INT64 value represented as a string. |
Clustering
Configures table clustering.
JSON representation |
---|
{ "fields": [ string ] } |
Fields | |
---|---|
fields[] |
One or more fields on which data should be clustered. Only top-level, non-repeated, simple-type fields are supported. The ordering of the clustering fields should be prioritized from most to least important for filtering purposes. For additional information, see Introduction to clustered tables. |
PartitioningDefinition
The partitioning information, which includes managed table, external table and metastore partitioned table partition information.
JSON representation |
---|
{
"partitionedColumn": [
{
object ( |
Fields | |
---|---|
partitioned |
Optional. Details about each partitioning column. This field is output only for all partitioning types other than metastore partitioned tables. BigQuery native tables only support 1 partitioning column. Other table types may support 0, 1 or more partitioning columns. For metastore partitioned tables, the order must match the definition order in the Hive Metastore, where it must match the physical layout of the table. For example, CREATE TABLE a_table(id BIGINT, name STRING) PARTITIONED BY (city STRING, state STRING). In this case the values must be ['city', 'state'] in that order. |
PartitionedColumn
The partitioning column information.
JSON representation |
---|
{ "field": string } |
Fields | |
---|---|
field |
Required. The name of the partition column. |
ViewDefinition
Describes the definition of a logical view.
JSON representation |
---|
{ "query": string, "userDefinedFunctionResources": [ { object ( |
Fields | |
---|---|
query |
Required. A query that BigQuery executes when the view is referenced. |
user |
Describes user-defined function resources used in the query. |
use |
Specifies whether to use BigQuery's legacy SQL for this view. The default value is true. If set to false, the view will use BigQuery's GoogleSQL: https://cloud.google.com/bigquery/sql-reference/ Queries and views that reference this view must use the same flag value. A wrapper is used here because the default value is True. |
privacy |
Optional. Specifices the privacy policy for the view. |
UserDefinedFunctionResource
This is used for defining User Defined Function (UDF) resources only when using legacy SQL. Users of GoogleSQL should leverage either DDL (e.g. CREATE [TEMPORARY] FUNCTION ... ) or the Routines API to define UDF resources.
For additional information on migrating, see: https://cloud.google.com/bigquery/docs/reference/standard-sql/migrating-from-legacy-sql#differences_in_user-defined_javascript_functions
JSON representation |
---|
{ "resourceUri": string, "inlineCode": string } |
Fields | |
---|---|
resource |
[Pick one] A code resource to load from a Google Cloud Storage URI (gs://bucket/path). |
inline |
[Pick one] An inline resource that contains code for a user-defined function (UDF). Providing a inline code resource is equivalent to providing a URI for a file containing the same code. |
PrivacyPolicy
Represents privacy policy that contains the privacy requirements specified by the data owner. Currently, this is only supported on views.
JSON representation |
---|
{ // Union field |
Fields | |
---|---|
Union field privacy_policy . Privacy policy associated with this requirement specification. Only one of the privacy methods is allowed per data source object. privacy_policy can be only one of the following: |
|
aggregation |
Optional. Policy used for aggregation thresholds. |
AggregationThresholdPolicy
Represents privacy policy associated with "aggregation threshold" method.
JSON representation |
---|
{ "privacyUnitColumns": [ string ], "threshold": string } |
Fields | |
---|---|
privacy |
Optional. The privacy unit column(s) associated with this policy. For now, only one column per data source object (table, view) is allowed as a privacy unit column. Representing as a repeated field in metadata for extensibility to multiple columns in future. Duplicates and Repeated struct fields are not allowed. For nested fields, use dot notation ("outer.inner") |
threshold |
Optional. The threshold for the "aggregation threshold" policy. |
MaterializedViewDefinition
Definition and configuration of a materialized view.
JSON representation |
---|
{ "query": string, "lastRefreshTime": string, "enableRefresh": boolean, "refreshIntervalMs": string, "allowNonIncrementalDefinition": boolean } |
Fields | |
---|---|
query |
Required. A query whose results are persisted. |
last |
Output only. The time when this materialized view was last refreshed, in milliseconds since the epoch. |
enable |
Optional. Enable automatic refresh of the materialized view when the base table is updated. The default value is "true". |
refresh |
Optional. The maximum frequency at which this materialized view will be refreshed. The default value is "1800000" (30 minutes). |
allow |
Optional. This option declares the intention to construct a materialized view that isn't refreshed incrementally. Non-incremental materialized views support an expanded range of SQL queries. The |
MaterializedViewStatus
Status of a materialized view. The last refresh timestamp status is omitted here, but is present in the MaterializedViewDefinition message.
JSON representation |
---|
{
"refreshWatermark": string,
"lastRefreshStatus": {
object ( |
Fields | |
---|---|
refresh |
Output only. Refresh watermark of materialized view. The base tables' data were collected into the materialized view cache until this time. |
last |
Output only. Error result of the last automatic refresh. If present, indicates that the last automatic refresh was unsuccessful. |
ErrorProto
Error details.
JSON representation |
---|
{ "reason": string, "location": string, "debugInfo": string, "message": string } |
Fields | |
---|---|
reason |
A short error code that summarizes the error. |
location |
Specifies where the error occurred, if present. |
debug |
Debugging information. This property is internal to Google and should not be used. |
message |
A human-readable description of the error. |
ExternalDataConfiguration
JSON representation |
---|
{ "sourceUris": [ string ], "fileSetSpecType": enum ( |
Fields | |
---|---|
source |
[Required] The fully-qualified URIs that point to your data in Google Cloud. For Google Cloud Storage URIs: Each URI can contain one '*' wildcard character and it must come after the 'bucket' name. Size limits related to load jobs apply to external data sources. For Google Cloud Bigtable URIs: Exactly one URI can be specified and it has be a fully specified and valid HTTPS URL for a Google Cloud Bigtable table. For Google Cloud Datastore backups, exactly one URI can be specified. Also, the '*' wildcard character is not allowed. |
file |
Optional. Specifies how source URIs are interpreted for constructing the file set to load. By default source URIs are expanded against the underlying storage. Other options include specifying manifest files. Only applicable to object storage systems. |
schema |
Optional. The schema for the data. Schema is required for CSV and JSON formats if autodetect is not on. Schema is disallowed for Google Cloud Bigtable, Cloud Datastore backups, Avro, ORC and Parquet formats. |
source |
[Required] The data format. For CSV files, specify "CSV". For Google sheets, specify "GOOGLE_SHEETS". For newline-delimited JSON, specify "NEWLINE_DELIMITED_JSON". For Avro files, specify "AVRO". For Google Cloud Datastore backups, specify "DATASTORE_BACKUP". For Apache Iceberg tables, specify "ICEBERG". For ORC files, specify "ORC". For Parquet files, specify "PARQUET". [Beta] For Google Cloud Bigtable, specify "BIGTABLE". |
max |
Optional. The maximum number of bad records that BigQuery can ignore when reading data. If the number of bad records exceeds this value, an invalid error is returned in the job result. The default value is 0, which requires that all records are valid. This setting is ignored for Google Cloud Bigtable, Google Cloud Datastore backups, Avro, ORC and Parquet formats. |
autodetect |
Try to detect schema and format options automatically. Any option specified explicitly will be honored. |
ignore |
Optional. Indicates if BigQuery should allow extra values that are not represented in the table schema. If true, the extra values are ignored. If false, records with extra columns are treated as bad records, and if there are too many bad records, an invalid error is returned in the job result. The default value is false. The sourceFormat property determines what BigQuery treats as an extra value: CSV: Trailing columns JSON: Named values that don't match any column names Google Cloud Bigtable: This setting is ignored. Google Cloud Datastore backups: This setting is ignored. Avro: This setting is ignored. ORC: This setting is ignored. Parquet: This setting is ignored. |
compression |
Optional. The compression type of the data source. Possible values include GZIP and NONE. The default value is NONE. This setting is ignored for Google Cloud Bigtable, Google Cloud Datastore backups, Avro, ORC and Parquet formats. An empty string is an invalid value. |
csv |
Optional. Additional properties to set if sourceFormat is set to CSV. |
json |
Optional. Additional properties to set if sourceFormat is set to JSON. |
bigtable |
Optional. Additional options if sourceFormat is set to BIGTABLE. |
google |
Optional. Additional options if sourceFormat is set to GOOGLE_SHEETS. |
hive |
Optional. When set, configures hive partitioning support. Not all storage formats support hive partitioning -- requesting hive partitioning on an unsupported format will lead to an error, as will providing an invalid specification. |
connection |
Optional. The connection specifying the credentials to be used to read external storage, such as Azure Blob, Cloud Storage, or S3. The connectionId can have the form |
decimal |
Defines the list of possible SQL data types to which the source decimal values are converted. This list and the precision and the scale parameters of the decimal field determine the target type. In the order of NUMERIC, BIGNUMERIC, and STRING, a type is picked if it is in the specified list and if it supports the precision and the scale. STRING supports all precision and scale values. If none of the listed types supports the precision and the scale, the type supporting the widest range in the specified list is picked, and if a value exceeds the supported range when reading the data, an error will be thrown. Example: Suppose the value of this field is ["NUMERIC", "BIGNUMERIC"]. If (precision,scale) is:
This field cannot contain duplicate types. The order of the types in this field is ignored. For example, ["BIGNUMERIC", "NUMERIC"] is the same as ["NUMERIC", "BIGNUMERIC"] and NUMERIC always takes precedence over BIGNUMERIC. Defaults to ["NUMERIC", "STRING"] for ORC and ["NUMERIC"] for the other file formats. |
avro |
Optional. Additional properties to set if sourceFormat is set to AVRO. |
json |
Optional. Load option to be used together with sourceFormat newline-delimited JSON to indicate that a variant of JSON is being loaded. To load newline-delimited GeoJSON, specify GEOJSON (and sourceFormat must be set to NEWLINE_DELIMITED_JSON). |
parquet |
Optional. Additional properties to set if sourceFormat is set to PARQUET. |
reference |
Optional. When creating an external table, the user can provide a reference file with the table schema. This is enabled for the following formats: AVRO, PARQUET, ORC. |
metadata |
Optional. Metadata Cache Mode for the table. Set this to enable caching of metadata from external data source. |
object |
Optional. ObjectMetadata is used to create Object Tables. Object Tables contain a listing of objects (with their metadata) found at the sourceUris. If ObjectMetadata is set, sourceFormat should be omitted. Currently SIMPLE is the only supported Object Metadata type. |
FileSetSpecType
This enum defines how to interpret source URIs for load jobs and external tables.
Enums | |
---|---|
FILE_SET_SPEC_TYPE_FILE_SYSTEM_MATCH |
This option expands source URIs by listing files from the object store. It is the default behavior if FileSetSpecType is not set. |
FILE_SET_SPEC_TYPE_NEW_LINE_DELIMITED_MANIFEST |
This option indicates that the provided URIs are newline-delimited manifest files, with one URI per line. Wildcard URIs are not supported. |
CsvOptions
Information related to a CSV data source.
JSON representation |
---|
{ "fieldDelimiter": string, "skipLeadingRows": string, "quote": string, "allowQuotedNewlines": boolean, "allowJaggedRows": boolean, "encoding": string, "preserveAsciiControlCharacters": boolean, "nullMarker": string } |
Fields | |
---|---|
field |
Optional. The separator character for fields in a CSV file. The separator is interpreted as a single byte. For files encoded in ISO-8859-1, any single character can be used as a separator. For files encoded in UTF-8, characters represented in decimal range 1-127 (U+0001-U+007F) can be used without any modification. UTF-8 characters encoded with multiple bytes (i.e. U+0080 and above) will have only the first byte used for separating fields. The remaining bytes will be treated as a part of the field. BigQuery also supports the escape sequence "\t" (U+0009) to specify a tab separator. The default value is comma (",", U+002C). |
skip |
Optional. The number of rows at the top of a CSV file that BigQuery will skip when reading the data. The default value is 0. This property is useful if you have header rows in the file that should be skipped. When autodetect is on, the behavior is the following:
|
quote |
Optional. The value that is used to quote data sections in a CSV file. BigQuery converts the string to ISO-8859-1 encoding, and then uses the first byte of the encoded string to split the data in its raw, binary state. The default value is a double-quote ("). If your data does not contain quoted sections, set the property value to an empty string. If your data contains quoted newline characters, you must also set the allowQuotedNewlines property to true. To include the specific quote character within a quoted value, precede it with an additional matching quote character. For example, if you want to escape the default character ' " ', use ' "" '. |
allow |
Optional. Indicates if BigQuery should allow quoted data sections that contain newline characters in a CSV file. The default value is false. |
allow |
Optional. Indicates if BigQuery should accept rows that are missing trailing optional columns. If true, BigQuery treats missing trailing columns as null values. If false, records with missing trailing columns are treated as bad records, and if there are too many bad records, an invalid error is returned in the job result. The default value is false. |
encoding |
Optional. The character encoding of the data. The supported values are UTF-8, ISO-8859-1, UTF-16BE, UTF-16LE, UTF-32BE, and UTF-32LE. The default value is UTF-8. BigQuery decodes the data after the raw, binary data has been split using the values of the quote and fieldDelimiter properties. |
preserve |
Optional. Indicates if the embedded ASCII control characters (the first 32 characters in the ASCII-table, from '\x00' to '\x1F') are preserved. |
null |
Optional. Specifies a string that represents a null value in a CSV file. For example, if you specify "\N", BigQuery interprets "\N" as a null value when querying a CSV file. The default value is the empty string. If you set this property to a custom value, BigQuery throws an error if an empty string is present for all data types except for STRING and BYTE. For STRING and BYTE columns, BigQuery interprets the empty string as an empty value. |
JsonOptions
Json Options for load and make external tables.
JSON representation |
---|
{ "encoding": string } |
Fields | |
---|---|
encoding |
Optional. The character encoding of the data. The supported values are UTF-8, UTF-16BE, UTF-16LE, UTF-32BE, and UTF-32LE. The default value is UTF-8. |
BigtableOptions
Options specific to Google Cloud Bigtable data sources.
JSON representation |
---|
{
"columnFamilies": [
{
object ( |
Fields | |
---|---|
column |
Optional. tabledata.list of column families to expose in the table schema along with their types. This list restricts the column families that can be referenced in queries and specifies their value types. You can use this list to do type conversions - see the 'type' field for more details. If you leave this list empty, all column families are present in the table schema and their values are read as BYTES. During a query only the column families referenced in that query are read from Bigtable. |
ignore |
Optional. If field is true, then the column families that are not specified in columnFamilies list are not exposed in the table schema. Otherwise, they are read with BYTES type values. The default value is false. |
read |
Optional. If field is true, then the rowkey column families will be read and converted to string. Otherwise they are read with BYTES type values and users need to manually cast them with CAST if necessary. The default value is false. |
output |
Optional. If field is true, then each column family will be read as a single JSON column. Otherwise they are read as a repeated cell structure containing timestamp/value tuples. The default value is false. |
BigtableColumnFamily
Information related to a Bigtable column family.
JSON representation |
---|
{
"familyId": string,
"type": string,
"encoding": string,
"columns": [
{
object ( |
Fields | |
---|---|
family |
Identifier of the column family. |
type |
Optional. The type to convert the value in cells of this column family. The values are expected to be encoded using HBase Bytes.toBytes function when using the BINARY encoding value. Following BigQuery types are allowed (case-sensitive):
Default type is BYTES. This can be overridden for a specific column by listing that column in 'columns' and specifying a type for it. |
encoding |
Optional. The encoding of the values when the type is not STRING. Acceptable encoding values are: TEXT - indicates values are alphanumeric text strings. BINARY - indicates values are encoded using HBase Bytes.toBytes family of functions. This can be overridden for a specific column by listing that column in 'columns' and specifying an encoding for it. |
columns[] |
Optional. Lists of columns that should be exposed as individual fields as opposed to a list of (column name, value) pairs. All columns whose qualifier matches a qualifier in this list can be accessed as |
only |
Optional. If this is set only the latest version of value are exposed for all columns in this column family. This can be overridden for a specific column by listing that column in 'columns' and specifying a different setting for that column. |
BigtableColumn
Information related to a Bigtable column.
JSON representation |
---|
{ "qualifierEncoded": string, "qualifierString": string, "fieldName": string, "type": string, "encoding": string, "onlyReadLatest": boolean } |
Fields | |
---|---|
qualifier |
[Required] Qualifier of the column. Columns in the parent column family that has this exact qualifier are exposed as |
qualifier |
Qualifier string. |
field |
Optional. If the qualifier is not a valid BigQuery field identifier i.e. does not match [a-zA-Z][a-zA-Z0-9_]*, a valid identifier must be provided as the column field name and is used as field name in queries. |
type |
Optional. The type to convert the value in cells of this column. The values are expected to be encoded using HBase Bytes.toBytes function when using the BINARY encoding value. Following BigQuery types are allowed (case-sensitive):
Default type is BYTES. 'type' can also be set at the column family level. However, the setting at this level takes precedence if 'type' is set at both levels. |
encoding |
Optional. The encoding of the values when the type is not STRING. Acceptable encoding values are: TEXT - indicates values are alphanumeric text strings. BINARY - indicates values are encoded using HBase Bytes.toBytes family of functions. 'encoding' can also be set at the column family level. However, the setting at this level takes precedence if 'encoding' is set at both levels. |
only |
Optional. If this is set, only the latest version of value in this column are exposed. 'onlyReadLatest' can also be set at the column family level. However, the setting at this level takes precedence if 'onlyReadLatest' is set at both levels. |
GoogleSheetsOptions
Options specific to Google Sheets data sources.
JSON representation |
---|
{ "skipLeadingRows": string, "range": string } |
Fields | |
---|---|
skip |
Optional. The number of rows at the top of a sheet that BigQuery will skip when reading the data. The default value is 0. This property is useful if you have header rows that should be skipped. When autodetect is on, the behavior is the following: * skipLeadingRows unspecified - Autodetect tries to detect headers in the first row. If they are not detected, the row is read as data. Otherwise data is read starting from the second row. * skipLeadingRows is 0 - Instructs autodetect that there are no headers and data should be read starting from the first row. * skipLeadingRows = N > 0 - Autodetect skips N-1 rows and tries to detect headers in row N. If headers are not detected, row N is just skipped. Otherwise row N is used to extract column names for the detected schema. |
range |
Optional. Range of a sheet to query from. Only used when non-empty. Typical format: sheet_name!top_left_cell_id:bottom_right_cell_id For example: sheet1!A1:B20 |
HivePartitioningOptions
Options for configuring hive partitioning detect.
JSON representation |
---|
{ "mode": string, "sourceUriPrefix": string, "requirePartitionFilter": boolean, "fields": [ string ] } |
Fields | |
---|---|
mode |
Optional. When set, what mode of hive partitioning to use when reading data. The following modes are supported:
Not all storage formats support hive partitioning. Requesting hive partitioning on an unsupported format will lead to an error. Currently supported formats are: JSON, CSV, ORC, Avro and Parquet. |
source |
Optional. When hive partition detection is requested, a common prefix for all source uris must be required. The prefix must end immediately before the partition key encoding begins. For example, consider files following this data layout: gs://bucket/path_to_table/dt=2019-06-01/country=USA/id=7/file.avro gs://bucket/path_to_table/dt=2019-05-31/country=CA/id=3/file.avro When hive partitioning is requested with either AUTO or STRINGS detection, the common prefix can be either of gs://bucket/path_to_table or gs://bucket/path_to_table/. CUSTOM detection requires encoding the partitioning schema immediately after the common prefix. For CUSTOM, any of
would all be valid source URI prefixes. |
require |
Optional. If set to true, queries over this table require a partition filter that can be used for partition elimination to be specified. Note that this field should only be true when creating a permanent external table or querying a temporary external table. Hive-partitioned loads with requirePartitionFilter explicitly set to true will fail. |
fields[] |
Output only. For permanent external tables, this field is populated with the hive partition keys in the order they were inferred. The types of the partition keys can be deduced by checking the table schema (which will include the partition keys). Not every API will populate this field in the output. For example, Tables.Get will populate it, but Tables.List will not contain this field. |
DecimalTargetType
The data types that could be used as a target type when converting decimal values.
Enums | |
---|---|
DECIMAL_TARGET_TYPE_UNSPECIFIED |
Invalid type. |
NUMERIC |
Decimal values could be converted to NUMERIC type. |
BIGNUMERIC |
Decimal values could be converted to BIGNUMERIC type. |
STRING |
Decimal values could be converted to STRING type. |
AvroOptions
Options for external data sources.
JSON representation |
---|
{ "useAvroLogicalTypes": boolean } |
Fields | |
---|---|
use |
Optional. If sourceFormat is set to "AVRO", indicates whether to interpret logical types as the corresponding BigQuery data type (for example, TIMESTAMP), instead of using the raw type (for example, INTEGER). |
JsonExtension
Used to indicate that a JSON variant, rather than normal JSON, is being used as the sourceFormat. This should only be used in combination with the JSON source format.
Enums | |
---|---|
JSON_EXTENSION_UNSPECIFIED |
The default if provided value is not one included in the enum, or the value is not specified. The source formate is parsed without any modification. |
GEOJSON |
Use GeoJSON variant of JSON. See https://tools.ietf.org/html/rfc7946. |
ParquetOptions
Parquet Options for load and make external tables.
JSON representation |
---|
{
"enumAsString": boolean,
"enableListInference": boolean,
"mapTargetType": enum ( |
Fields | |
---|---|
enum |
Optional. Indicates whether to infer Parquet ENUM logical type as STRING instead of BYTES by default. |
enable |
Optional. Indicates whether to use schema inference specifically for Parquet LIST logical type. |
map |
Optional. Indicates how to represent a Parquet map if present. |
MapTargetType
Indicates the map target type. Only applies to parquet maps.
Enums | |
---|---|
MAP_TARGET_TYPE_UNSPECIFIED |
In this mode, the map will have the following schema: struct map_field_name { repeated struct key_value { key value } }. |
ARRAY_OF_STRUCT |
In this mode, the map will have the following schema: repeated struct map_field_name { key value }. |
ObjectMetadata
Supported Object Metadata Types.
Enums | |
---|---|
OBJECT_METADATA_UNSPECIFIED |
Unspecified by default. |
SIMPLE |
Directory listing of objects. |
MetadataCacheMode
MetadataCacheMode identifies if the table should use metadata caching for files from external source (eg Google Cloud Storage).
Enums | |
---|---|
METADATA_CACHE_MODE_UNSPECIFIED |
Unspecified metadata cache mode. |
AUTOMATIC |
Set this mode to trigger automatic background refresh of metadata cache from the external source. Queries will use the latest available cache version within the table's maxStaleness interval. |
MANUAL |
Set this mode to enable triggering manual refresh of the metadata cache from external source. Queries will use the latest manually triggered cache version within the table's maxStaleness interval. |
BigLakeConfiguration
Configuration for BigLake managed tables.
JSON representation |
---|
{ "connectionId": string, "storageUri": string, "fileFormat": enum ( |
Fields | |
---|---|
connection |
Optional. The connection specifying the credentials to be used to read and write to external storage, such as Cloud Storage. The connectionId can have the form |
storage |
Optional. The fully qualified location prefix of the external folder where table data is stored. The '*' wildcard character is not allowed. The URI should be in the format |
file |
Optional. The file format the table data is stored in. |
table |
Optional. The table format the metadata only snapshots are stored in. |
FileFormat
Supported file formats for BigLake tables.
Enums | |
---|---|
FILE_FORMAT_UNSPECIFIED |
Default Value. |
PARQUET |
Apache Parquet format. |
TableFormat
Supported table formats for BigLake tables.
Enums | |
---|---|
TABLE_FORMAT_UNSPECIFIED |
Default Value. |
ICEBERG |
Apache Iceberg format. |
Streamingbuffer
JSON representation |
---|
{ "estimatedBytes": string, "estimatedRows": string, "oldestEntryTime": string } |
Fields | |
---|---|
estimated |
Output only. A lower-bound estimate of the number of bytes currently in the streaming buffer. |
estimated |
Output only. A lower-bound estimate of the number of rows currently in the streaming buffer. |
oldest |
Output only. Contains the timestamp of the oldest entry in the streaming buffer, in milliseconds since the epoch, if the streaming buffer is available. |
SnapshotDefinition
Information about base table and snapshot time of the snapshot.
JSON representation |
---|
{
"baseTableReference": {
object ( |
Fields | |
---|---|
base |
Required. Reference describing the ID of the table that was snapshot. |
snapshot |
Required. The time at which the base table was snapshot. This value is reported in the JSON response using RFC3339 format. |
CloneDefinition
Information about base table and clone time of a table clone.
JSON representation |
---|
{
"baseTableReference": {
object ( |
Fields | |
---|---|
base |
Required. Reference describing the ID of the table that was cloned. |
clone |
Required. The time at which the base table was cloned. This value is reported in the JSON response using RFC3339 format. |
TableConstraints
The TableConstraints defines the primary key and foreign key.
JSON representation |
---|
{ "primaryKey": { object ( |
Fields | |
---|---|
primary |
Optional. Represents a primary key constraint on a table's columns. Present only if the table has a primary key. The primary key is not enforced. |
foreign |
Optional. Present only if the table has a foreign key. The foreign key is not enforced. |
PrimaryKey
Represents the primary key constraint on a table's columns.
JSON representation |
---|
{ "columns": [ string ] } |
Fields | |
---|---|
columns[] |
Required. The columns that are composed of the primary key constraint. |
ForeignKey
Represents a foreign key constraint on a table's columns.
JSON representation |
---|
{ "name": string, "referencedTable": { object ( |
Fields | |
---|---|
name |
Optional. Set only if the foreign key constraint is named. |
referenced |
Required. The table that holds the primary key and is referenced by this foreign key. |
column |
Required. The columns that compose the foreign key. |
ColumnReference
The pair of the foreign key column and primary key column.
JSON representation |
---|
{ "referencingColumn": string, "referencedColumn": string } |
Fields | |
---|---|
referencing |
Required. The column that composes the foreign key. |
referenced |
Required. The column in the primary key that are referenced by the referencingColumn. |
ExternalCatalogTableOptions
Metadata about open source compatible table. The fields contained in these options correspond to Hive metastore's table-level properties.
JSON representation |
---|
{
"parameters": {
string: string,
...
},
"storageDescriptor": {
object ( |
Fields | |
---|---|
parameters |
Optional. A map of the key-value pairs defining the parameters and properties of the open source table. Corresponds with Hive metastore table parameters. Maximum size of 4MiB. |
storage |
Optional. A storage descriptor containing information about the physical storage of this table. |
connection |
Optional. A connection ID that specifies the credentials to be used to read external storage, such as Azure Blob, Cloud Storage, or Amazon S3. This connection is needed to read the open source table from BigQuery. The connectionId format must be either |
StorageDescriptor
Contains information about how a table's data is stored and accessed by open source query engines.
JSON representation |
---|
{
"locationUri": string,
"inputFormat": string,
"outputFormat": string,
"serdeInfo": {
object ( |
Fields | |
---|---|
location |
Optional. The physical location of the table (e.g. |
input |
Optional. Specifies the fully qualified class name of the InputFormat (e.g. "org.apache.hadoop.hive.ql.io.orc.OrcInputFormat"). The maximum length is 128 characters. |
output |
Optional. Specifies the fully qualified class name of the OutputFormat (e.g. "org.apache.hadoop.hive.ql.io.orc.OrcOutputFormat"). The maximum length is 128 characters. |
serde |
Optional. Serializer and deserializer information. |
SerDeInfo
Serializer and deserializer information.
JSON representation |
---|
{ "name": string, "serializationLibrary": string, "parameters": { string: string, ... } } |
Fields | |
---|---|
name |
Optional. Name of the SerDe. The maximum length is 256 characters. |
serialization |
Required. Specifies a fully-qualified class name of the serialization library that is responsible for the translation of data between table representation and the underlying low-level input and output format structures. The maximum length is 256 characters. |
parameters |
Optional. Key-value pairs that define the initialization parameters for the serialization library. Maximum size 10 Kib. |
Methods |
|
---|---|
|
Deletes the table specified by tableId from the dataset. |
|
Gets the specified table resource by table ID. |
|
Gets the access control policy for a resource. |
|
Creates a new, empty table in the dataset. |
|
Lists all tables in the specified dataset. |
|
Updates information in an existing table. |
|
Sets the access control policy on the specified resource. |
|
Returns permissions that a caller has on the specified resource. |
|
Updates information in an existing table. |