All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pulumi.gcp.bigquery.kotlin.Job.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 8.12.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.bigquery.kotlin

import com.pulumi.core.Output
import com.pulumi.gcp.bigquery.kotlin.outputs.JobCopy
import com.pulumi.gcp.bigquery.kotlin.outputs.JobExtract
import com.pulumi.gcp.bigquery.kotlin.outputs.JobLoad
import com.pulumi.gcp.bigquery.kotlin.outputs.JobQuery
import com.pulumi.gcp.bigquery.kotlin.outputs.JobStatus
import com.pulumi.kotlin.KotlinCustomResource
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.ResourceMapper
import com.pulumi.kotlin.options.CustomResourceOptions
import com.pulumi.kotlin.options.CustomResourceOptionsBuilder
import com.pulumi.resources.Resource
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.collections.Map
import com.pulumi.gcp.bigquery.kotlin.outputs.JobCopy.Companion.toKotlin as jobCopyToKotlin
import com.pulumi.gcp.bigquery.kotlin.outputs.JobExtract.Companion.toKotlin as jobExtractToKotlin
import com.pulumi.gcp.bigquery.kotlin.outputs.JobLoad.Companion.toKotlin as jobLoadToKotlin
import com.pulumi.gcp.bigquery.kotlin.outputs.JobQuery.Companion.toKotlin as jobQueryToKotlin
import com.pulumi.gcp.bigquery.kotlin.outputs.JobStatus.Companion.toKotlin as jobStatusToKotlin

/**
 * Builder for [Job].
 */
@PulumiTagMarker
public class JobResourceBuilder internal constructor() {
    public var name: String? = null

    public var args: JobArgs = JobArgs()

    public var opts: CustomResourceOptions = CustomResourceOptions()

    /**
     * @param name The _unique_ name of the resulting resource.
     */
    public fun name(`value`: String) {
        this.name = value
    }

    /**
     * @param block The arguments to use to populate this resource's properties.
     */
    public suspend fun args(block: suspend JobArgsBuilder.() -> Unit) {
        val builder = JobArgsBuilder()
        block(builder)
        this.args = builder.build()
    }

    /**
     * @param block A bag of options that control this resource's behavior.
     */
    public suspend fun opts(block: suspend CustomResourceOptionsBuilder.() -> Unit) {
        this.opts = com.pulumi.kotlin.options.CustomResourceOptions.opts(block)
    }

    internal fun build(): Job {
        val builtJavaResource = com.pulumi.gcp.bigquery.Job(
            this.name,
            this.args.toJava(),
            this.opts.toJava(),
        )
        return Job(builtJavaResource)
    }
}

/**
 * Jobs are actions that BigQuery runs on your behalf to load data, export data, query data, or copy data.
 * Once a BigQuery job is created, it cannot be changed or deleted.
 * To get more information about Job, see:
 * * [API documentation](https://cloud.google.com/bigquery/docs/reference/rest/v2/jobs)
 * * How-to Guides
 *     * [BigQuery Jobs Intro](https://cloud.google.com/bigquery/docs/jobs-overview)
 * ## Example Usage
 * ### Bigquery Job Query
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const bar = new gcp.bigquery.Dataset("bar", {
 *     datasetId: "job_query_dataset",
 *     friendlyName: "test",
 *     description: "This is a test description",
 *     location: "US",
 * });
 * const foo = new gcp.bigquery.Table("foo", {
 *     deletionProtection: false,
 *     datasetId: bar.datasetId,
 *     tableId: "job_query_table",
 * });
 * const job = new gcp.bigquery.Job("job", {
 *     jobId: "job_query",
 *     labels: {
 *         "example-label": "example-value",
 *     },
 *     query: {
 *         query: "SELECT state FROM [lookerdata:cdc.project_tycho_reports]",
 *         destinationTable: {
 *             projectId: foo.project,
 *             datasetId: foo.datasetId,
 *             tableId: foo.tableId,
 *         },
 *         allowLargeResults: true,
 *         flattenResults: true,
 *         scriptOptions: {
 *             keyResultStatement: "LAST",
 *         },
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * bar = gcp.bigquery.Dataset("bar",
 *     dataset_id="job_query_dataset",
 *     friendly_name="test",
 *     description="This is a test description",
 *     location="US")
 * foo = gcp.bigquery.Table("foo",
 *     deletion_protection=False,
 *     dataset_id=bar.dataset_id,
 *     table_id="job_query_table")
 * job = gcp.bigquery.Job("job",
 *     job_id="job_query",
 *     labels={
 *         "example-label": "example-value",
 *     },
 *     query=gcp.bigquery.JobQueryArgs(
 *         query="SELECT state FROM [lookerdata:cdc.project_tycho_reports]",
 *         destination_table=gcp.bigquery.JobQueryDestinationTableArgs(
 *             project_id=foo.project,
 *             dataset_id=foo.dataset_id,
 *             table_id=foo.table_id,
 *         ),
 *         allow_large_results=True,
 *         flatten_results=True,
 *         script_options=gcp.bigquery.JobQueryScriptOptionsArgs(
 *             key_result_statement="LAST",
 *         ),
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var bar = new Gcp.BigQuery.Dataset("bar", new()
 *     {
 *         DatasetId = "job_query_dataset",
 *         FriendlyName = "test",
 *         Description = "This is a test description",
 *         Location = "US",
 *     });
 *     var foo = new Gcp.BigQuery.Table("foo", new()
 *     {
 *         DeletionProtection = false,
 *         DatasetId = bar.DatasetId,
 *         TableId = "job_query_table",
 *     });
 *     var job = new Gcp.BigQuery.Job("job", new()
 *     {
 *         JobId = "job_query",
 *         Labels =
 *         {
 *             { "example-label", "example-value" },
 *         },
 *         Query = new Gcp.BigQuery.Inputs.JobQueryArgs
 *         {
 *             Query = "SELECT state FROM [lookerdata:cdc.project_tycho_reports]",
 *             DestinationTable = new Gcp.BigQuery.Inputs.JobQueryDestinationTableArgs
 *             {
 *                 ProjectId = foo.Project,
 *                 DatasetId = foo.DatasetId,
 *                 TableId = foo.TableId,
 *             },
 *             AllowLargeResults = true,
 *             FlattenResults = true,
 *             ScriptOptions = new Gcp.BigQuery.Inputs.JobQueryScriptOptionsArgs
 *             {
 *                 KeyResultStatement = "LAST",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/bigquery"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		bar, err := bigquery.NewDataset(ctx, "bar", &bigquery.DatasetArgs{
 * 			DatasetId:    pulumi.String("job_query_dataset"),
 * 			FriendlyName: pulumi.String("test"),
 * 			Description:  pulumi.String("This is a test description"),
 * 			Location:     pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		foo, err := bigquery.NewTable(ctx, "foo", &bigquery.TableArgs{
 * 			DeletionProtection: pulumi.Bool(false),
 * 			DatasetId:          bar.DatasetId,
 * 			TableId:            pulumi.String("job_query_table"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewJob(ctx, "job", &bigquery.JobArgs{
 * 			JobId: pulumi.String("job_query"),
 * 			Labels: pulumi.StringMap{
 * 				"example-label": pulumi.String("example-value"),
 * 			},
 * 			Query: &bigquery.JobQueryArgs{
 * 				Query: pulumi.String("SELECT state FROM [lookerdata:cdc.project_tycho_reports]"),
 * 				DestinationTable: &bigquery.JobQueryDestinationTableArgs{
 * 					ProjectId: foo.Project,
 * 					DatasetId: foo.DatasetId,
 * 					TableId:   foo.TableId,
 * 				},
 * 				AllowLargeResults: pulumi.Bool(true),
 * 				FlattenResults:    pulumi.Bool(true),
 * 				ScriptOptions: &bigquery.JobQueryScriptOptionsArgs{
 * 					KeyResultStatement: pulumi.String("LAST"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.bigquery.Dataset;
 * import com.pulumi.gcp.bigquery.DatasetArgs;
 * import com.pulumi.gcp.bigquery.Table;
 * import com.pulumi.gcp.bigquery.TableArgs;
 * import com.pulumi.gcp.bigquery.Job;
 * import com.pulumi.gcp.bigquery.JobArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobQueryArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobQueryDestinationTableArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobQueryScriptOptionsArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var bar = new Dataset("bar", DatasetArgs.builder()
 *             .datasetId("job_query_dataset")
 *             .friendlyName("test")
 *             .description("This is a test description")
 *             .location("US")
 *             .build());
 *         var foo = new Table("foo", TableArgs.builder()
 *             .deletionProtection(false)
 *             .datasetId(bar.datasetId())
 *             .tableId("job_query_table")
 *             .build());
 *         var job = new Job("job", JobArgs.builder()
 *             .jobId("job_query")
 *             .labels(Map.of("example-label", "example-value"))
 *             .query(JobQueryArgs.builder()
 *                 .query("SELECT state FROM [lookerdata:cdc.project_tycho_reports]")
 *                 .destinationTable(JobQueryDestinationTableArgs.builder()
 *                     .projectId(foo.project())
 *                     .datasetId(foo.datasetId())
 *                     .tableId(foo.tableId())
 *                     .build())
 *                 .allowLargeResults(true)
 *                 .flattenResults(true)
 *                 .scriptOptions(JobQueryScriptOptionsArgs.builder()
 *                     .keyResultStatement("LAST")
 *                     .build())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   foo:
 *     type: gcp:bigquery:Table
 *     properties:
 *       deletionProtection: false
 *       datasetId: ${bar.datasetId}
 *       tableId: job_query_table
 *   bar:
 *     type: gcp:bigquery:Dataset
 *     properties:
 *       datasetId: job_query_dataset
 *       friendlyName: test
 *       description: This is a test description
 *       location: US
 *   job:
 *     type: gcp:bigquery:Job
 *     properties:
 *       jobId: job_query
 *       labels:
 *         example-label: example-value
 *       query:
 *         query: SELECT state FROM [lookerdata:cdc.project_tycho_reports]
 *         destinationTable:
 *           projectId: ${foo.project}
 *           datasetId: ${foo.datasetId}
 *           tableId: ${foo.tableId}
 *         allowLargeResults: true
 *         flattenResults: true
 *         scriptOptions:
 *           keyResultStatement: LAST
 * ```
 * 
 * ### Bigquery Job Query Table Reference
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const bar = new gcp.bigquery.Dataset("bar", {
 *     datasetId: "job_query_dataset",
 *     friendlyName: "test",
 *     description: "This is a test description",
 *     location: "US",
 * });
 * const foo = new gcp.bigquery.Table("foo", {
 *     deletionProtection: false,
 *     datasetId: bar.datasetId,
 *     tableId: "job_query_table",
 * });
 * const job = new gcp.bigquery.Job("job", {
 *     jobId: "job_query",
 *     labels: {
 *         "example-label": "example-value",
 *     },
 *     query: {
 *         query: "SELECT state FROM [lookerdata:cdc.project_tycho_reports]",
 *         destinationTable: {
 *             tableId: foo.id,
 *         },
 *         defaultDataset: {
 *             datasetId: bar.id,
 *         },
 *         allowLargeResults: true,
 *         flattenResults: true,
 *         scriptOptions: {
 *             keyResultStatement: "LAST",
 *         },
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * bar = gcp.bigquery.Dataset("bar",
 *     dataset_id="job_query_dataset",
 *     friendly_name="test",
 *     description="This is a test description",
 *     location="US")
 * foo = gcp.bigquery.Table("foo",
 *     deletion_protection=False,
 *     dataset_id=bar.dataset_id,
 *     table_id="job_query_table")
 * job = gcp.bigquery.Job("job",
 *     job_id="job_query",
 *     labels={
 *         "example-label": "example-value",
 *     },
 *     query=gcp.bigquery.JobQueryArgs(
 *         query="SELECT state FROM [lookerdata:cdc.project_tycho_reports]",
 *         destination_table=gcp.bigquery.JobQueryDestinationTableArgs(
 *             table_id=foo.id,
 *         ),
 *         default_dataset=gcp.bigquery.JobQueryDefaultDatasetArgs(
 *             dataset_id=bar.id,
 *         ),
 *         allow_large_results=True,
 *         flatten_results=True,
 *         script_options=gcp.bigquery.JobQueryScriptOptionsArgs(
 *             key_result_statement="LAST",
 *         ),
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var bar = new Gcp.BigQuery.Dataset("bar", new()
 *     {
 *         DatasetId = "job_query_dataset",
 *         FriendlyName = "test",
 *         Description = "This is a test description",
 *         Location = "US",
 *     });
 *     var foo = new Gcp.BigQuery.Table("foo", new()
 *     {
 *         DeletionProtection = false,
 *         DatasetId = bar.DatasetId,
 *         TableId = "job_query_table",
 *     });
 *     var job = new Gcp.BigQuery.Job("job", new()
 *     {
 *         JobId = "job_query",
 *         Labels =
 *         {
 *             { "example-label", "example-value" },
 *         },
 *         Query = new Gcp.BigQuery.Inputs.JobQueryArgs
 *         {
 *             Query = "SELECT state FROM [lookerdata:cdc.project_tycho_reports]",
 *             DestinationTable = new Gcp.BigQuery.Inputs.JobQueryDestinationTableArgs
 *             {
 *                 TableId = foo.Id,
 *             },
 *             DefaultDataset = new Gcp.BigQuery.Inputs.JobQueryDefaultDatasetArgs
 *             {
 *                 DatasetId = bar.Id,
 *             },
 *             AllowLargeResults = true,
 *             FlattenResults = true,
 *             ScriptOptions = new Gcp.BigQuery.Inputs.JobQueryScriptOptionsArgs
 *             {
 *                 KeyResultStatement = "LAST",
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/bigquery"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		bar, err := bigquery.NewDataset(ctx, "bar", &bigquery.DatasetArgs{
 * 			DatasetId:    pulumi.String("job_query_dataset"),
 * 			FriendlyName: pulumi.String("test"),
 * 			Description:  pulumi.String("This is a test description"),
 * 			Location:     pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		foo, err := bigquery.NewTable(ctx, "foo", &bigquery.TableArgs{
 * 			DeletionProtection: pulumi.Bool(false),
 * 			DatasetId:          bar.DatasetId,
 * 			TableId:            pulumi.String("job_query_table"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewJob(ctx, "job", &bigquery.JobArgs{
 * 			JobId: pulumi.String("job_query"),
 * 			Labels: pulumi.StringMap{
 * 				"example-label": pulumi.String("example-value"),
 * 			},
 * 			Query: &bigquery.JobQueryArgs{
 * 				Query: pulumi.String("SELECT state FROM [lookerdata:cdc.project_tycho_reports]"),
 * 				DestinationTable: &bigquery.JobQueryDestinationTableArgs{
 * 					TableId: foo.ID(),
 * 				},
 * 				DefaultDataset: &bigquery.JobQueryDefaultDatasetArgs{
 * 					DatasetId: bar.ID(),
 * 				},
 * 				AllowLargeResults: pulumi.Bool(true),
 * 				FlattenResults:    pulumi.Bool(true),
 * 				ScriptOptions: &bigquery.JobQueryScriptOptionsArgs{
 * 					KeyResultStatement: pulumi.String("LAST"),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.bigquery.Dataset;
 * import com.pulumi.gcp.bigquery.DatasetArgs;
 * import com.pulumi.gcp.bigquery.Table;
 * import com.pulumi.gcp.bigquery.TableArgs;
 * import com.pulumi.gcp.bigquery.Job;
 * import com.pulumi.gcp.bigquery.JobArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobQueryArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobQueryDestinationTableArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobQueryDefaultDatasetArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobQueryScriptOptionsArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var bar = new Dataset("bar", DatasetArgs.builder()
 *             .datasetId("job_query_dataset")
 *             .friendlyName("test")
 *             .description("This is a test description")
 *             .location("US")
 *             .build());
 *         var foo = new Table("foo", TableArgs.builder()
 *             .deletionProtection(false)
 *             .datasetId(bar.datasetId())
 *             .tableId("job_query_table")
 *             .build());
 *         var job = new Job("job", JobArgs.builder()
 *             .jobId("job_query")
 *             .labels(Map.of("example-label", "example-value"))
 *             .query(JobQueryArgs.builder()
 *                 .query("SELECT state FROM [lookerdata:cdc.project_tycho_reports]")
 *                 .destinationTable(JobQueryDestinationTableArgs.builder()
 *                     .tableId(foo.id())
 *                     .build())
 *                 .defaultDataset(JobQueryDefaultDatasetArgs.builder()
 *                     .datasetId(bar.id())
 *                     .build())
 *                 .allowLargeResults(true)
 *                 .flattenResults(true)
 *                 .scriptOptions(JobQueryScriptOptionsArgs.builder()
 *                     .keyResultStatement("LAST")
 *                     .build())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   foo:
 *     type: gcp:bigquery:Table
 *     properties:
 *       deletionProtection: false
 *       datasetId: ${bar.datasetId}
 *       tableId: job_query_table
 *   bar:
 *     type: gcp:bigquery:Dataset
 *     properties:
 *       datasetId: job_query_dataset
 *       friendlyName: test
 *       description: This is a test description
 *       location: US
 *   job:
 *     type: gcp:bigquery:Job
 *     properties:
 *       jobId: job_query
 *       labels:
 *         example-label: example-value
 *       query:
 *         query: SELECT state FROM [lookerdata:cdc.project_tycho_reports]
 *         destinationTable:
 *           tableId: ${foo.id}
 *         defaultDataset:
 *           datasetId: ${bar.id}
 *         allowLargeResults: true
 *         flattenResults: true
 *         scriptOptions:
 *           keyResultStatement: LAST
 * ```
 * 
 * ### Bigquery Job Load
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const bar = new gcp.bigquery.Dataset("bar", {
 *     datasetId: "job_load_dataset",
 *     friendlyName: "test",
 *     description: "This is a test description",
 *     location: "US",
 * });
 * const foo = new gcp.bigquery.Table("foo", {
 *     deletionProtection: false,
 *     datasetId: bar.datasetId,
 *     tableId: "job_load_table",
 * });
 * const job = new gcp.bigquery.Job("job", {
 *     jobId: "job_load",
 *     labels: {
 *         my_job: "load",
 *     },
 *     load: {
 *         sourceUris: ["gs://cloud-samples-data/bigquery/us-states/us-states-by-date.csv"],
 *         destinationTable: {
 *             projectId: foo.project,
 *             datasetId: foo.datasetId,
 *             tableId: foo.tableId,
 *         },
 *         skipLeadingRows: 1,
 *         schemaUpdateOptions: [
 *             "ALLOW_FIELD_RELAXATION",
 *             "ALLOW_FIELD_ADDITION",
 *         ],
 *         writeDisposition: "WRITE_APPEND",
 *         autodetect: true,
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * bar = gcp.bigquery.Dataset("bar",
 *     dataset_id="job_load_dataset",
 *     friendly_name="test",
 *     description="This is a test description",
 *     location="US")
 * foo = gcp.bigquery.Table("foo",
 *     deletion_protection=False,
 *     dataset_id=bar.dataset_id,
 *     table_id="job_load_table")
 * job = gcp.bigquery.Job("job",
 *     job_id="job_load",
 *     labels={
 *         "my_job": "load",
 *     },
 *     load=gcp.bigquery.JobLoadArgs(
 *         source_uris=["gs://cloud-samples-data/bigquery/us-states/us-states-by-date.csv"],
 *         destination_table=gcp.bigquery.JobLoadDestinationTableArgs(
 *             project_id=foo.project,
 *             dataset_id=foo.dataset_id,
 *             table_id=foo.table_id,
 *         ),
 *         skip_leading_rows=1,
 *         schema_update_options=[
 *             "ALLOW_FIELD_RELAXATION",
 *             "ALLOW_FIELD_ADDITION",
 *         ],
 *         write_disposition="WRITE_APPEND",
 *         autodetect=True,
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var bar = new Gcp.BigQuery.Dataset("bar", new()
 *     {
 *         DatasetId = "job_load_dataset",
 *         FriendlyName = "test",
 *         Description = "This is a test description",
 *         Location = "US",
 *     });
 *     var foo = new Gcp.BigQuery.Table("foo", new()
 *     {
 *         DeletionProtection = false,
 *         DatasetId = bar.DatasetId,
 *         TableId = "job_load_table",
 *     });
 *     var job = new Gcp.BigQuery.Job("job", new()
 *     {
 *         JobId = "job_load",
 *         Labels =
 *         {
 *             { "my_job", "load" },
 *         },
 *         Load = new Gcp.BigQuery.Inputs.JobLoadArgs
 *         {
 *             SourceUris = new[]
 *             {
 *                 "gs://cloud-samples-data/bigquery/us-states/us-states-by-date.csv",
 *             },
 *             DestinationTable = new Gcp.BigQuery.Inputs.JobLoadDestinationTableArgs
 *             {
 *                 ProjectId = foo.Project,
 *                 DatasetId = foo.DatasetId,
 *                 TableId = foo.TableId,
 *             },
 *             SkipLeadingRows = 1,
 *             SchemaUpdateOptions = new[]
 *             {
 *                 "ALLOW_FIELD_RELAXATION",
 *                 "ALLOW_FIELD_ADDITION",
 *             },
 *             WriteDisposition = "WRITE_APPEND",
 *             Autodetect = true,
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/bigquery"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		bar, err := bigquery.NewDataset(ctx, "bar", &bigquery.DatasetArgs{
 * 			DatasetId:    pulumi.String("job_load_dataset"),
 * 			FriendlyName: pulumi.String("test"),
 * 			Description:  pulumi.String("This is a test description"),
 * 			Location:     pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		foo, err := bigquery.NewTable(ctx, "foo", &bigquery.TableArgs{
 * 			DeletionProtection: pulumi.Bool(false),
 * 			DatasetId:          bar.DatasetId,
 * 			TableId:            pulumi.String("job_load_table"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewJob(ctx, "job", &bigquery.JobArgs{
 * 			JobId: pulumi.String("job_load"),
 * 			Labels: pulumi.StringMap{
 * 				"my_job": pulumi.String("load"),
 * 			},
 * 			Load: &bigquery.JobLoadArgs{
 * 				SourceUris: pulumi.StringArray{
 * 					pulumi.String("gs://cloud-samples-data/bigquery/us-states/us-states-by-date.csv"),
 * 				},
 * 				DestinationTable: &bigquery.JobLoadDestinationTableArgs{
 * 					ProjectId: foo.Project,
 * 					DatasetId: foo.DatasetId,
 * 					TableId:   foo.TableId,
 * 				},
 * 				SkipLeadingRows: pulumi.Int(1),
 * 				SchemaUpdateOptions: pulumi.StringArray{
 * 					pulumi.String("ALLOW_FIELD_RELAXATION"),
 * 					pulumi.String("ALLOW_FIELD_ADDITION"),
 * 				},
 * 				WriteDisposition: pulumi.String("WRITE_APPEND"),
 * 				Autodetect:       pulumi.Bool(true),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.bigquery.Dataset;
 * import com.pulumi.gcp.bigquery.DatasetArgs;
 * import com.pulumi.gcp.bigquery.Table;
 * import com.pulumi.gcp.bigquery.TableArgs;
 * import com.pulumi.gcp.bigquery.Job;
 * import com.pulumi.gcp.bigquery.JobArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobLoadArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobLoadDestinationTableArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var bar = new Dataset("bar", DatasetArgs.builder()
 *             .datasetId("job_load_dataset")
 *             .friendlyName("test")
 *             .description("This is a test description")
 *             .location("US")
 *             .build());
 *         var foo = new Table("foo", TableArgs.builder()
 *             .deletionProtection(false)
 *             .datasetId(bar.datasetId())
 *             .tableId("job_load_table")
 *             .build());
 *         var job = new Job("job", JobArgs.builder()
 *             .jobId("job_load")
 *             .labels(Map.of("my_job", "load"))
 *             .load(JobLoadArgs.builder()
 *                 .sourceUris("gs://cloud-samples-data/bigquery/us-states/us-states-by-date.csv")
 *                 .destinationTable(JobLoadDestinationTableArgs.builder()
 *                     .projectId(foo.project())
 *                     .datasetId(foo.datasetId())
 *                     .tableId(foo.tableId())
 *                     .build())
 *                 .skipLeadingRows(1)
 *                 .schemaUpdateOptions(
 *                     "ALLOW_FIELD_RELAXATION",
 *                     "ALLOW_FIELD_ADDITION")
 *                 .writeDisposition("WRITE_APPEND")
 *                 .autodetect(true)
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   foo:
 *     type: gcp:bigquery:Table
 *     properties:
 *       deletionProtection: false
 *       datasetId: ${bar.datasetId}
 *       tableId: job_load_table
 *   bar:
 *     type: gcp:bigquery:Dataset
 *     properties:
 *       datasetId: job_load_dataset
 *       friendlyName: test
 *       description: This is a test description
 *       location: US
 *   job:
 *     type: gcp:bigquery:Job
 *     properties:
 *       jobId: job_load
 *       labels:
 *         my_job: load
 *       load:
 *         sourceUris:
 *           - gs://cloud-samples-data/bigquery/us-states/us-states-by-date.csv
 *         destinationTable:
 *           projectId: ${foo.project}
 *           datasetId: ${foo.datasetId}
 *           tableId: ${foo.tableId}
 *         skipLeadingRows: 1
 *         schemaUpdateOptions:
 *           - ALLOW_FIELD_RELAXATION
 *           - ALLOW_FIELD_ADDITION
 *         writeDisposition: WRITE_APPEND
 *         autodetect: true
 * ```
 * 
 * ### Bigquery Job Load Geojson
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const project = "my-project-name";
 * const bucket = new gcp.storage.Bucket("bucket", {
 *     name: `${project}-bq-geojson`,
 *     location: "US",
 *     uniformBucketLevelAccess: true,
 * });
 * const object = new gcp.storage.BucketObject("object", {
 *     name: "geojson-data.jsonl",
 *     bucket: bucket.name,
 *     content: `{"type":"Feature","properties":{"continent":"Europe","region":"Scandinavia"},"geometry":{"type":"Polygon","coordinates":[[[-30.94,53.33],[33.05,53.33],[33.05,71.86],[-30.94,71.86],[-30.94,53.33]]]}}
 * {"type":"Feature","properties":{"continent":"Africa","region":"West Africa"},"geometry":{"type":"Polygon","coordinates":[[[-23.91,0],[11.95,0],[11.95,18.98],[-23.91,18.98],[-23.91,0]]]}}
 * `,
 * });
 * const bar = new gcp.bigquery.Dataset("bar", {
 *     datasetId: "job_load_dataset",
 *     friendlyName: "test",
 *     description: "This is a test description",
 *     location: "US",
 * });
 * const foo = new gcp.bigquery.Table("foo", {
 *     deletionProtection: false,
 *     datasetId: bar.datasetId,
 *     tableId: "job_load_table",
 * });
 * const job = new gcp.bigquery.Job("job", {
 *     jobId: "job_load",
 *     labels: {
 *         my_job: "load",
 *     },
 *     load: {
 *         sourceUris: [pulumi.interpolate`gs://${object.bucket}/${object.name}`],
 *         destinationTable: {
 *             projectId: foo.project,
 *             datasetId: foo.datasetId,
 *             tableId: foo.tableId,
 *         },
 *         writeDisposition: "WRITE_TRUNCATE",
 *         autodetect: true,
 *         sourceFormat: "NEWLINE_DELIMITED_JSON",
 *         jsonExtension: "GEOJSON",
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * project = "my-project-name"
 * bucket = gcp.storage.Bucket("bucket",
 *     name=f"{project}-bq-geojson",
 *     location="US",
 *     uniform_bucket_level_access=True)
 * object = gcp.storage.BucketObject("object",
 *     name="geojson-data.jsonl",
 *     bucket=bucket.name,
 *     content="""{"type":"Feature","properties":{"continent":"Europe","region":"Scandinavia"},"geometry":{"type":"Polygon","coordinates":[[[-30.94,53.33],[33.05,53.33],[33.05,71.86],[-30.94,71.86],[-30.94,53.33]]]}}
 * {"type":"Feature","properties":{"continent":"Africa","region":"West Africa"},"geometry":{"type":"Polygon","coordinates":[[[-23.91,0],[11.95,0],[11.95,18.98],[-23.91,18.98],[-23.91,0]]]}}
 * """)
 * bar = gcp.bigquery.Dataset("bar",
 *     dataset_id="job_load_dataset",
 *     friendly_name="test",
 *     description="This is a test description",
 *     location="US")
 * foo = gcp.bigquery.Table("foo",
 *     deletion_protection=False,
 *     dataset_id=bar.dataset_id,
 *     table_id="job_load_table")
 * job = gcp.bigquery.Job("job",
 *     job_id="job_load",
 *     labels={
 *         "my_job": "load",
 *     },
 *     load=gcp.bigquery.JobLoadArgs(
 *         source_uris=[pulumi.Output.all(object.bucket, object.name).apply(lambda bucket, name: f"gs://{bucket}/{name}")],
 *         destination_table=gcp.bigquery.JobLoadDestinationTableArgs(
 *             project_id=foo.project,
 *             dataset_id=foo.dataset_id,
 *             table_id=foo.table_id,
 *         ),
 *         write_disposition="WRITE_TRUNCATE",
 *         autodetect=True,
 *         source_format="NEWLINE_DELIMITED_JSON",
 *         json_extension="GEOJSON",
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var project = "my-project-name";
 *     var bucket = new Gcp.Storage.Bucket("bucket", new()
 *     {
 *         Name = $"{project}-bq-geojson",
 *         Location = "US",
 *         UniformBucketLevelAccess = true,
 *     });
 *     var @object = new Gcp.Storage.BucketObject("object", new()
 *     {
 *         Name = "geojson-data.jsonl",
 *         Bucket = bucket.Name,
 *         Content = @"{""type"":""Feature"",""properties"":{""continent"":""Europe"",""region"":""Scandinavia""},""geometry"":{""type"":""Polygon"",""coordinates"":[[[-30.94,53.33],[33.05,53.33],[33.05,71.86],[-30.94,71.86],[-30.94,53.33]]]}}
 * {""type"":""Feature"",""properties"":{""continent"":""Africa"",""region"":""West Africa""},""geometry"":{""type"":""Polygon"",""coordinates"":[[[-23.91,0],[11.95,0],[11.95,18.98],[-23.91,18.98],[-23.91,0]]]}}
 * ",
 *     });
 *     var bar = new Gcp.BigQuery.Dataset("bar", new()
 *     {
 *         DatasetId = "job_load_dataset",
 *         FriendlyName = "test",
 *         Description = "This is a test description",
 *         Location = "US",
 *     });
 *     var foo = new Gcp.BigQuery.Table("foo", new()
 *     {
 *         DeletionProtection = false,
 *         DatasetId = bar.DatasetId,
 *         TableId = "job_load_table",
 *     });
 *     var job = new Gcp.BigQuery.Job("job", new()
 *     {
 *         JobId = "job_load",
 *         Labels =
 *         {
 *             { "my_job", "load" },
 *         },
 *         Load = new Gcp.BigQuery.Inputs.JobLoadArgs
 *         {
 *             SourceUris = new[]
 *             {
 *                 Output.Tuple(@object.Bucket, @object.Name).Apply(values =>
 *                 {
 *                     var bucket = values.Item1;
 *                     var name = values.Item2;
 *                     return $"gs://{bucket}/{name}";
 *                 }),
 *             },
 *             DestinationTable = new Gcp.BigQuery.Inputs.JobLoadDestinationTableArgs
 *             {
 *                 ProjectId = foo.Project,
 *                 DatasetId = foo.DatasetId,
 *                 TableId = foo.TableId,
 *             },
 *             WriteDisposition = "WRITE_TRUNCATE",
 *             Autodetect = true,
 *             SourceFormat = "NEWLINE_DELIMITED_JSON",
 *             JsonExtension = "GEOJSON",
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"fmt"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/bigquery"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		project := "my-project-name"
 * 		bucket, err := storage.NewBucket(ctx, "bucket", &storage.BucketArgs{
 * 			Name:                     pulumi.String(fmt.Sprintf("%v-bq-geojson", project)),
 * 			Location:                 pulumi.String("US"),
 * 			UniformBucketLevelAccess: pulumi.Bool(true),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		object, err := storage.NewBucketObject(ctx, "object", &storage.BucketObjectArgs{
 * 			Name:    pulumi.String("geojson-data.jsonl"),
 * 			Bucket:  bucket.Name,
 * 			Content: pulumi.String("{\"type\":\"Feature\",\"properties\":{\"continent\":\"Europe\",\"region\":\"Scandinavia\"},\"geometry\":{\"type\":\"Polygon\",\"coordinates\":[[[-30.94,53.33],[33.05,53.33],[33.05,71.86],[-30.94,71.86],[-30.94,53.33]]]}}\n{\"type\":\"Feature\",\"properties\":{\"continent\":\"Africa\",\"region\":\"West Africa\"},\"geometry\":{\"type\":\"Polygon\",\"coordinates\":[[[-23.91,0],[11.95,0],[11.95,18.98],[-23.91,18.98],[-23.91,0]]]}}\n"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		bar, err := bigquery.NewDataset(ctx, "bar", &bigquery.DatasetArgs{
 * 			DatasetId:    pulumi.String("job_load_dataset"),
 * 			FriendlyName: pulumi.String("test"),
 * 			Description:  pulumi.String("This is a test description"),
 * 			Location:     pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		foo, err := bigquery.NewTable(ctx, "foo", &bigquery.TableArgs{
 * 			DeletionProtection: pulumi.Bool(false),
 * 			DatasetId:          bar.DatasetId,
 * 			TableId:            pulumi.String("job_load_table"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewJob(ctx, "job", &bigquery.JobArgs{
 * 			JobId: pulumi.String("job_load"),
 * 			Labels: pulumi.StringMap{
 * 				"my_job": pulumi.String("load"),
 * 			},
 * 			Load: &bigquery.JobLoadArgs{
 * 				SourceUris: pulumi.StringArray{
 * 					pulumi.All(object.Bucket, object.Name).ApplyT(func(_args []interface{}) (string, error) {
 * 						bucket := _args[0].(string)
 * 						name := _args[1].(string)
 * 						return fmt.Sprintf("gs://%v/%v", bucket, name), nil
 * 					}).(pulumi.StringOutput),
 * 				},
 * 				DestinationTable: &bigquery.JobLoadDestinationTableArgs{
 * 					ProjectId: foo.Project,
 * 					DatasetId: foo.DatasetId,
 * 					TableId:   foo.TableId,
 * 				},
 * 				WriteDisposition: pulumi.String("WRITE_TRUNCATE"),
 * 				Autodetect:       pulumi.Bool(true),
 * 				SourceFormat:     pulumi.String("NEWLINE_DELIMITED_JSON"),
 * 				JsonExtension:    pulumi.String("GEOJSON"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.storage.Bucket;
 * import com.pulumi.gcp.storage.BucketArgs;
 * import com.pulumi.gcp.storage.BucketObject;
 * import com.pulumi.gcp.storage.BucketObjectArgs;
 * import com.pulumi.gcp.bigquery.Dataset;
 * import com.pulumi.gcp.bigquery.DatasetArgs;
 * import com.pulumi.gcp.bigquery.Table;
 * import com.pulumi.gcp.bigquery.TableArgs;
 * import com.pulumi.gcp.bigquery.Job;
 * import com.pulumi.gcp.bigquery.JobArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobLoadArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobLoadDestinationTableArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         final var project = "my-project-name";
 *         var bucket = new Bucket("bucket", BucketArgs.builder()
 *             .name(String.format("%s-bq-geojson", project))
 *             .location("US")
 *             .uniformBucketLevelAccess(true)
 *             .build());
 *         var object = new BucketObject("object", BucketObjectArgs.builder()
 *             .name("geojson-data.jsonl")
 *             .bucket(bucket.name())
 *             .content("""
 * {"type":"Feature","properties":{"continent":"Europe","region":"Scandinavia"},"geometry":{"type":"Polygon","coordinates":[[[-30.94,53.33],[33.05,53.33],[33.05,71.86],[-30.94,71.86],[-30.94,53.33]]]}}
 * {"type":"Feature","properties":{"continent":"Africa","region":"West Africa"},"geometry":{"type":"Polygon","coordinates":[[[-23.91,0],[11.95,0],[11.95,18.98],[-23.91,18.98],[-23.91,0]]]}}
 *             """)
 *             .build());
 *         var bar = new Dataset("bar", DatasetArgs.builder()
 *             .datasetId("job_load_dataset")
 *             .friendlyName("test")
 *             .description("This is a test description")
 *             .location("US")
 *             .build());
 *         var foo = new Table("foo", TableArgs.builder()
 *             .deletionProtection(false)
 *             .datasetId(bar.datasetId())
 *             .tableId("job_load_table")
 *             .build());
 *         var job = new Job("job", JobArgs.builder()
 *             .jobId("job_load")
 *             .labels(Map.of("my_job", "load"))
 *             .load(JobLoadArgs.builder()
 *                 .sourceUris(Output.tuple(object.bucket(), object.name()).applyValue(values -> {
 *                     var bucket = values.t1;
 *                     var name = values.t2;
 *                     return String.format("gs://%s/%s", bucket,name);
 *                 }))
 *                 .destinationTable(JobLoadDestinationTableArgs.builder()
 *                     .projectId(foo.project())
 *                     .datasetId(foo.datasetId())
 *                     .tableId(foo.tableId())
 *                     .build())
 *                 .writeDisposition("WRITE_TRUNCATE")
 *                 .autodetect(true)
 *                 .sourceFormat("NEWLINE_DELIMITED_JSON")
 *                 .jsonExtension("GEOJSON")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   bucket:
 *     type: gcp:storage:Bucket
 *     properties:
 *       name: ${project}-bq-geojson
 *       location: US
 *       uniformBucketLevelAccess: true
 *   object:
 *     type: gcp:storage:BucketObject
 *     properties:
 *       name: geojson-data.jsonl
 *       bucket: ${bucket.name}
 *       content: |
 *         {"type":"Feature","properties":{"continent":"Europe","region":"Scandinavia"},"geometry":{"type":"Polygon","coordinates":[[[-30.94,53.33],[33.05,53.33],[33.05,71.86],[-30.94,71.86],[-30.94,53.33]]]}}
 *         {"type":"Feature","properties":{"continent":"Africa","region":"West Africa"},"geometry":{"type":"Polygon","coordinates":[[[-23.91,0],[11.95,0],[11.95,18.98],[-23.91,18.98],[-23.91,0]]]}}
 *   foo:
 *     type: gcp:bigquery:Table
 *     properties:
 *       deletionProtection: false
 *       datasetId: ${bar.datasetId}
 *       tableId: job_load_table
 *   bar:
 *     type: gcp:bigquery:Dataset
 *     properties:
 *       datasetId: job_load_dataset
 *       friendlyName: test
 *       description: This is a test description
 *       location: US
 *   job:
 *     type: gcp:bigquery:Job
 *     properties:
 *       jobId: job_load
 *       labels:
 *         my_job: load
 *       load:
 *         sourceUris:
 *           - gs://${object.bucket}/${object.name}
 *         destinationTable:
 *           projectId: ${foo.project}
 *           datasetId: ${foo.datasetId}
 *           tableId: ${foo.tableId}
 *         writeDisposition: WRITE_TRUNCATE
 *         autodetect: true
 *         sourceFormat: NEWLINE_DELIMITED_JSON
 *         jsonExtension: GEOJSON
 * variables:
 *   project: my-project-name
 * ```
 * 
 * ### Bigquery Job Load Parquet
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const test = new gcp.storage.Bucket("test", {
 *     name: "job_load_bucket",
 *     location: "US",
 *     uniformBucketLevelAccess: true,
 * });
 * const testBucketObject = new gcp.storage.BucketObject("test", {
 *     name: "job_load_bucket_object",
 *     source: new pulumi.asset.FileAsset("./test-fixtures/test.parquet.gzip"),
 *     bucket: test.name,
 * });
 * const testDataset = new gcp.bigquery.Dataset("test", {
 *     datasetId: "job_load_dataset",
 *     friendlyName: "test",
 *     description: "This is a test description",
 *     location: "US",
 * });
 * const testTable = new gcp.bigquery.Table("test", {
 *     deletionProtection: false,
 *     tableId: "job_load_table",
 *     datasetId: testDataset.datasetId,
 * });
 * const job = new gcp.bigquery.Job("job", {
 *     jobId: "job_load",
 *     labels: {
 *         my_job: "load",
 *     },
 *     load: {
 *         sourceUris: [pulumi.interpolate`gs://${testBucketObject.bucket}/${testBucketObject.name}`],
 *         destinationTable: {
 *             projectId: testTable.project,
 *             datasetId: testTable.datasetId,
 *             tableId: testTable.tableId,
 *         },
 *         schemaUpdateOptions: [
 *             "ALLOW_FIELD_RELAXATION",
 *             "ALLOW_FIELD_ADDITION",
 *         ],
 *         writeDisposition: "WRITE_APPEND",
 *         sourceFormat: "PARQUET",
 *         autodetect: true,
 *         parquetOptions: {
 *             enumAsString: true,
 *             enableListInference: true,
 *         },
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * test = gcp.storage.Bucket("test",
 *     name="job_load_bucket",
 *     location="US",
 *     uniform_bucket_level_access=True)
 * test_bucket_object = gcp.storage.BucketObject("test",
 *     name="job_load_bucket_object",
 *     source=pulumi.FileAsset("./test-fixtures/test.parquet.gzip"),
 *     bucket=test.name)
 * test_dataset = gcp.bigquery.Dataset("test",
 *     dataset_id="job_load_dataset",
 *     friendly_name="test",
 *     description="This is a test description",
 *     location="US")
 * test_table = gcp.bigquery.Table("test",
 *     deletion_protection=False,
 *     table_id="job_load_table",
 *     dataset_id=test_dataset.dataset_id)
 * job = gcp.bigquery.Job("job",
 *     job_id="job_load",
 *     labels={
 *         "my_job": "load",
 *     },
 *     load=gcp.bigquery.JobLoadArgs(
 *         source_uris=[pulumi.Output.all(test_bucket_object.bucket, test_bucket_object.name).apply(lambda bucket, name: f"gs://{bucket}/{name}")],
 *         destination_table=gcp.bigquery.JobLoadDestinationTableArgs(
 *             project_id=test_table.project,
 *             dataset_id=test_table.dataset_id,
 *             table_id=test_table.table_id,
 *         ),
 *         schema_update_options=[
 *             "ALLOW_FIELD_RELAXATION",
 *             "ALLOW_FIELD_ADDITION",
 *         ],
 *         write_disposition="WRITE_APPEND",
 *         source_format="PARQUET",
 *         autodetect=True,
 *         parquet_options=gcp.bigquery.JobLoadParquetOptionsArgs(
 *             enum_as_string=True,
 *             enable_list_inference=True,
 *         ),
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var test = new Gcp.Storage.Bucket("test", new()
 *     {
 *         Name = "job_load_bucket",
 *         Location = "US",
 *         UniformBucketLevelAccess = true,
 *     });
 *     var testBucketObject = new Gcp.Storage.BucketObject("test", new()
 *     {
 *         Name = "job_load_bucket_object",
 *         Source = new FileAsset("./test-fixtures/test.parquet.gzip"),
 *         Bucket = test.Name,
 *     });
 *     var testDataset = new Gcp.BigQuery.Dataset("test", new()
 *     {
 *         DatasetId = "job_load_dataset",
 *         FriendlyName = "test",
 *         Description = "This is a test description",
 *         Location = "US",
 *     });
 *     var testTable = new Gcp.BigQuery.Table("test", new()
 *     {
 *         DeletionProtection = false,
 *         TableId = "job_load_table",
 *         DatasetId = testDataset.DatasetId,
 *     });
 *     var job = new Gcp.BigQuery.Job("job", new()
 *     {
 *         JobId = "job_load",
 *         Labels =
 *         {
 *             { "my_job", "load" },
 *         },
 *         Load = new Gcp.BigQuery.Inputs.JobLoadArgs
 *         {
 *             SourceUris = new[]
 *             {
 *                 Output.Tuple(testBucketObject.Bucket, testBucketObject.Name).Apply(values =>
 *                 {
 *                     var bucket = values.Item1;
 *                     var name = values.Item2;
 *                     return $"gs://{bucket}/{name}";
 *                 }),
 *             },
 *             DestinationTable = new Gcp.BigQuery.Inputs.JobLoadDestinationTableArgs
 *             {
 *                 ProjectId = testTable.Project,
 *                 DatasetId = testTable.DatasetId,
 *                 TableId = testTable.TableId,
 *             },
 *             SchemaUpdateOptions = new[]
 *             {
 *                 "ALLOW_FIELD_RELAXATION",
 *                 "ALLOW_FIELD_ADDITION",
 *             },
 *             WriteDisposition = "WRITE_APPEND",
 *             SourceFormat = "PARQUET",
 *             Autodetect = true,
 *             ParquetOptions = new Gcp.BigQuery.Inputs.JobLoadParquetOptionsArgs
 *             {
 *                 EnumAsString = true,
 *                 EnableListInference = true,
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"fmt"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/bigquery"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		test, err := storage.NewBucket(ctx, "test", &storage.BucketArgs{
 * 			Name:                     pulumi.String("job_load_bucket"),
 * 			Location:                 pulumi.String("US"),
 * 			UniformBucketLevelAccess: pulumi.Bool(true),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		testBucketObject, err := storage.NewBucketObject(ctx, "test", &storage.BucketObjectArgs{
 * 			Name:   pulumi.String("job_load_bucket_object"),
 * 			Source: pulumi.NewFileAsset("./test-fixtures/test.parquet.gzip"),
 * 			Bucket: test.Name,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		testDataset, err := bigquery.NewDataset(ctx, "test", &bigquery.DatasetArgs{
 * 			DatasetId:    pulumi.String("job_load_dataset"),
 * 			FriendlyName: pulumi.String("test"),
 * 			Description:  pulumi.String("This is a test description"),
 * 			Location:     pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		testTable, err := bigquery.NewTable(ctx, "test", &bigquery.TableArgs{
 * 			DeletionProtection: pulumi.Bool(false),
 * 			TableId:            pulumi.String("job_load_table"),
 * 			DatasetId:          testDataset.DatasetId,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewJob(ctx, "job", &bigquery.JobArgs{
 * 			JobId: pulumi.String("job_load"),
 * 			Labels: pulumi.StringMap{
 * 				"my_job": pulumi.String("load"),
 * 			},
 * 			Load: &bigquery.JobLoadArgs{
 * 				SourceUris: pulumi.StringArray{
 * 					pulumi.All(testBucketObject.Bucket, testBucketObject.Name).ApplyT(func(_args []interface{}) (string, error) {
 * 						bucket := _args[0].(string)
 * 						name := _args[1].(string)
 * 						return fmt.Sprintf("gs://%v/%v", bucket, name), nil
 * 					}).(pulumi.StringOutput),
 * 				},
 * 				DestinationTable: &bigquery.JobLoadDestinationTableArgs{
 * 					ProjectId: testTable.Project,
 * 					DatasetId: testTable.DatasetId,
 * 					TableId:   testTable.TableId,
 * 				},
 * 				SchemaUpdateOptions: pulumi.StringArray{
 * 					pulumi.String("ALLOW_FIELD_RELAXATION"),
 * 					pulumi.String("ALLOW_FIELD_ADDITION"),
 * 				},
 * 				WriteDisposition: pulumi.String("WRITE_APPEND"),
 * 				SourceFormat:     pulumi.String("PARQUET"),
 * 				Autodetect:       pulumi.Bool(true),
 * 				ParquetOptions: &bigquery.JobLoadParquetOptionsArgs{
 * 					EnumAsString:        pulumi.Bool(true),
 * 					EnableListInference: pulumi.Bool(true),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.storage.Bucket;
 * import com.pulumi.gcp.storage.BucketArgs;
 * import com.pulumi.gcp.storage.BucketObject;
 * import com.pulumi.gcp.storage.BucketObjectArgs;
 * import com.pulumi.gcp.bigquery.Dataset;
 * import com.pulumi.gcp.bigquery.DatasetArgs;
 * import com.pulumi.gcp.bigquery.Table;
 * import com.pulumi.gcp.bigquery.TableArgs;
 * import com.pulumi.gcp.bigquery.Job;
 * import com.pulumi.gcp.bigquery.JobArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobLoadArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobLoadDestinationTableArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobLoadParquetOptionsArgs;
 * import com.pulumi.asset.FileAsset;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var test = new Bucket("test", BucketArgs.builder()
 *             .name("job_load_bucket")
 *             .location("US")
 *             .uniformBucketLevelAccess(true)
 *             .build());
 *         var testBucketObject = new BucketObject("testBucketObject", BucketObjectArgs.builder()
 *             .name("job_load_bucket_object")
 *             .source(new FileAsset("./test-fixtures/test.parquet.gzip"))
 *             .bucket(test.name())
 *             .build());
 *         var testDataset = new Dataset("testDataset", DatasetArgs.builder()
 *             .datasetId("job_load_dataset")
 *             .friendlyName("test")
 *             .description("This is a test description")
 *             .location("US")
 *             .build());
 *         var testTable = new Table("testTable", TableArgs.builder()
 *             .deletionProtection(false)
 *             .tableId("job_load_table")
 *             .datasetId(testDataset.datasetId())
 *             .build());
 *         var job = new Job("job", JobArgs.builder()
 *             .jobId("job_load")
 *             .labels(Map.of("my_job", "load"))
 *             .load(JobLoadArgs.builder()
 *                 .sourceUris(Output.tuple(testBucketObject.bucket(), testBucketObject.name()).applyValue(values -> {
 *                     var bucket = values.t1;
 *                     var name = values.t2;
 *                     return String.format("gs://%s/%s", bucket,name);
 *                 }))
 *                 .destinationTable(JobLoadDestinationTableArgs.builder()
 *                     .projectId(testTable.project())
 *                     .datasetId(testTable.datasetId())
 *                     .tableId(testTable.tableId())
 *                     .build())
 *                 .schemaUpdateOptions(
 *                     "ALLOW_FIELD_RELAXATION",
 *                     "ALLOW_FIELD_ADDITION")
 *                 .writeDisposition("WRITE_APPEND")
 *                 .sourceFormat("PARQUET")
 *                 .autodetect(true)
 *                 .parquetOptions(JobLoadParquetOptionsArgs.builder()
 *                     .enumAsString(true)
 *                     .enableListInference(true)
 *                     .build())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   test:
 *     type: gcp:storage:Bucket
 *     properties:
 *       name: job_load_bucket
 *       location: US
 *       uniformBucketLevelAccess: true
 *   testBucketObject:
 *     type: gcp:storage:BucketObject
 *     name: test
 *     properties:
 *       name: job_load_bucket_object
 *       source:
 *         fn::FileAsset: ./test-fixtures/test.parquet.gzip
 *       bucket: ${test.name}
 *   testDataset:
 *     type: gcp:bigquery:Dataset
 *     name: test
 *     properties:
 *       datasetId: job_load_dataset
 *       friendlyName: test
 *       description: This is a test description
 *       location: US
 *   testTable:
 *     type: gcp:bigquery:Table
 *     name: test
 *     properties:
 *       deletionProtection: false
 *       tableId: job_load_table
 *       datasetId: ${testDataset.datasetId}
 *   job:
 *     type: gcp:bigquery:Job
 *     properties:
 *       jobId: job_load
 *       labels:
 *         my_job: load
 *       load:
 *         sourceUris:
 *           - gs://${testBucketObject.bucket}/${testBucketObject.name}
 *         destinationTable:
 *           projectId: ${testTable.project}
 *           datasetId: ${testTable.datasetId}
 *           tableId: ${testTable.tableId}
 *         schemaUpdateOptions:
 *           - ALLOW_FIELD_RELAXATION
 *           - ALLOW_FIELD_ADDITION
 *         writeDisposition: WRITE_APPEND
 *         sourceFormat: PARQUET
 *         autodetect: true
 *         parquetOptions:
 *           enumAsString: true
 *           enableListInference: true
 * ```
 * 
 * ### Bigquery Job Copy
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const count = 2;
 * const sourceDataset: gcp.bigquery.Dataset[] = [];
 * for (const range = {value: 0}; range.value < count; range.value++) {
 *     sourceDataset.push(new gcp.bigquery.Dataset(`source-${range.value}`, {
 *         datasetId: `job_copy_${range.value}_dataset`,
 *         friendlyName: "test",
 *         description: "This is a test description",
 *         location: "US",
 *     }));
 * }
 * const source: gcp.bigquery.Table[] = [];
 * for (const range = {value: 0}; range.value < count; range.value++) {
 *     source.push(new gcp.bigquery.Table(`source-${range.value}`, {
 *         deletionProtection: false,
 *         datasetId: sourceDataset[range.value].datasetId,
 *         tableId: `job_copy_${range.value}_table`,
 *         schema: `[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * `,
 *     }));
 * }
 * const destDataset = new gcp.bigquery.Dataset("dest", {
 *     datasetId: "job_copy_dest_dataset",
 *     friendlyName: "test",
 *     description: "This is a test description",
 *     location: "US",
 * });
 * const keyRing = new gcp.kms.KeyRing("key_ring", {
 *     name: "example-keyring",
 *     location: "global",
 * });
 * const cryptoKey = new gcp.kms.CryptoKey("crypto_key", {
 *     name: "example-key",
 *     keyRing: keyRing.id,
 * });
 * const dest = new gcp.bigquery.Table("dest", {
 *     deletionProtection: false,
 *     datasetId: destDataset.datasetId,
 *     tableId: "job_copy_dest_table",
 *     schema: `[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * `,
 *     encryptionConfiguration: {
 *         kmsKeyName: cryptoKey.id,
 *     },
 * });
 * const project = gcp.organizations.getProject({
 *     projectId: "my-project-name",
 * });
 * const encryptRole = new gcp.projects.IAMMember("encrypt_role", {
 *     project: project.then(project => project.projectId),
 *     role: "roles/cloudkms.cryptoKeyEncrypterDecrypter",
 *     member: project.then(project => `serviceAccount:bq-${project.number}@bigquery-encryption.iam.gserviceaccount.com`),
 * });
 * const job = new gcp.bigquery.Job("job", {
 *     jobId: "job_copy",
 *     copy: {
 *         sourceTables: [
 *             {
 *                 projectId: source[0].project,
 *                 datasetId: source[0].datasetId,
 *                 tableId: source[0].tableId,
 *             },
 *             {
 *                 projectId: source[1].project,
 *                 datasetId: source[1].datasetId,
 *                 tableId: source[1].tableId,
 *             },
 *         ],
 *         destinationTable: {
 *             projectId: dest.project,
 *             datasetId: dest.datasetId,
 *             tableId: dest.tableId,
 *         },
 *         destinationEncryptionConfiguration: {
 *             kmsKeyName: cryptoKey.id,
 *         },
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * count = 2
 * source_dataset = []
 * for range in [{"value": i} for i in range(0, count)]:
 *     source_dataset.append(gcp.bigquery.Dataset(f"source-{range['value']}",
 *         dataset_id=f"job_copy_{range['value']}_dataset",
 *         friendly_name="test",
 *         description="This is a test description",
 *         location="US"))
 * source = []
 * for range in [{"value": i} for i in range(0, count)]:
 *     source.append(gcp.bigquery.Table(f"source-{range['value']}",
 *         deletion_protection=False,
 *         dataset_id=source_dataset[range["value"]].dataset_id,
 *         table_id=f"job_copy_{range['value']}_table",
 *         schema="""[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * """))
 * dest_dataset = gcp.bigquery.Dataset("dest",
 *     dataset_id="job_copy_dest_dataset",
 *     friendly_name="test",
 *     description="This is a test description",
 *     location="US")
 * key_ring = gcp.kms.KeyRing("key_ring",
 *     name="example-keyring",
 *     location="global")
 * crypto_key = gcp.kms.CryptoKey("crypto_key",
 *     name="example-key",
 *     key_ring=key_ring.id)
 * dest = gcp.bigquery.Table("dest",
 *     deletion_protection=False,
 *     dataset_id=dest_dataset.dataset_id,
 *     table_id="job_copy_dest_table",
 *     schema="""[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * """,
 *     encryption_configuration=gcp.bigquery.TableEncryptionConfigurationArgs(
 *         kms_key_name=crypto_key.id,
 *     ))
 * project = gcp.organizations.get_project(project_id="my-project-name")
 * encrypt_role = gcp.projects.IAMMember("encrypt_role",
 *     project=project.project_id,
 *     role="roles/cloudkms.cryptoKeyEncrypterDecrypter",
 *     member=f"serviceAccount:bq-{project.number}@bigquery-encryption.iam.gserviceaccount.com")
 * job = gcp.bigquery.Job("job",
 *     job_id="job_copy",
 *     copy=gcp.bigquery.JobCopyArgs(
 *         source_tables=[
 *             gcp.bigquery.JobCopySourceTableArgs(
 *                 project_id=source[0].project,
 *                 dataset_id=source[0].dataset_id,
 *                 table_id=source[0].table_id,
 *             ),
 *             gcp.bigquery.JobCopySourceTableArgs(
 *                 project_id=source[1].project,
 *                 dataset_id=source[1].dataset_id,
 *                 table_id=source[1].table_id,
 *             ),
 *         ],
 *         destination_table=gcp.bigquery.JobCopyDestinationTableArgs(
 *             project_id=dest.project,
 *             dataset_id=dest.dataset_id,
 *             table_id=dest.table_id,
 *         ),
 *         destination_encryption_configuration=gcp.bigquery.JobCopyDestinationEncryptionConfigurationArgs(
 *             kms_key_name=crypto_key.id,
 *         ),
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var count = 2;
 *     var sourceDataset = new List();
 *     for (var rangeIndex = 0; rangeIndex < count; rangeIndex++)
 *     {
 *         var range = new { Value = rangeIndex };
 *         sourceDataset.Add(new Gcp.BigQuery.Dataset($"source-{range.Value}", new()
 *         {
 *             DatasetId = $"job_copy_{range.Value}_dataset",
 *             FriendlyName = "test",
 *             Description = "This is a test description",
 *             Location = "US",
 *         }));
 *     }
 *     var source = new List();
 *     for (var rangeIndex = 0; rangeIndex < count; rangeIndex++)
 *     {
 *         var range = new { Value = rangeIndex };
 *         source.Add(new Gcp.BigQuery.Table($"source-{range.Value}", new()
 *         {
 *             DeletionProtection = false,
 *             DatasetId = sourceDataset[range.Value].DatasetId,
 *             TableId = $"job_copy_{range.Value}_table",
 *             Schema = @"[
 *   {
 *     ""name"": ""name"",
 *     ""type"": ""STRING"",
 *     ""mode"": ""NULLABLE""
 *   },
 *   {
 *     ""name"": ""post_abbr"",
 *     ""type"": ""STRING"",
 *     ""mode"": ""NULLABLE""
 *   },
 *   {
 *     ""name"": ""date"",
 *     ""type"": ""DATE"",
 *     ""mode"": ""NULLABLE""
 *   }
 * ]
 * ",
 *         }));
 *     }
 *     var destDataset = new Gcp.BigQuery.Dataset("dest", new()
 *     {
 *         DatasetId = "job_copy_dest_dataset",
 *         FriendlyName = "test",
 *         Description = "This is a test description",
 *         Location = "US",
 *     });
 *     var keyRing = new Gcp.Kms.KeyRing("key_ring", new()
 *     {
 *         Name = "example-keyring",
 *         Location = "global",
 *     });
 *     var cryptoKey = new Gcp.Kms.CryptoKey("crypto_key", new()
 *     {
 *         Name = "example-key",
 *         KeyRing = keyRing.Id,
 *     });
 *     var dest = new Gcp.BigQuery.Table("dest", new()
 *     {
 *         DeletionProtection = false,
 *         DatasetId = destDataset.DatasetId,
 *         TableId = "job_copy_dest_table",
 *         Schema = @"[
 *   {
 *     ""name"": ""name"",
 *     ""type"": ""STRING"",
 *     ""mode"": ""NULLABLE""
 *   },
 *   {
 *     ""name"": ""post_abbr"",
 *     ""type"": ""STRING"",
 *     ""mode"": ""NULLABLE""
 *   },
 *   {
 *     ""name"": ""date"",
 *     ""type"": ""DATE"",
 *     ""mode"": ""NULLABLE""
 *   }
 * ]
 * ",
 *         EncryptionConfiguration = new Gcp.BigQuery.Inputs.TableEncryptionConfigurationArgs
 *         {
 *             KmsKeyName = cryptoKey.Id,
 *         },
 *     });
 *     var project = Gcp.Organizations.GetProject.Invoke(new()
 *     {
 *         ProjectId = "my-project-name",
 *     });
 *     var encryptRole = new Gcp.Projects.IAMMember("encrypt_role", new()
 *     {
 *         Project = project.Apply(getProjectResult => getProjectResult.ProjectId),
 *         Role = "roles/cloudkms.cryptoKeyEncrypterDecrypter",
 *         Member = $"serviceAccount:bq-{project.Apply(getProjectResult => getProjectResult.Number)}@bigquery-encryption.iam.gserviceaccount.com",
 *     });
 *     var job = new Gcp.BigQuery.Job("job", new()
 *     {
 *         JobId = "job_copy",
 *         Copy = new Gcp.BigQuery.Inputs.JobCopyArgs
 *         {
 *             SourceTables = new[]
 *             {
 *                 new Gcp.BigQuery.Inputs.JobCopySourceTableArgs
 *                 {
 *                     ProjectId = source[0].Project,
 *                     DatasetId = source[0].DatasetId,
 *                     TableId = source[0].TableId,
 *                 },
 *                 new Gcp.BigQuery.Inputs.JobCopySourceTableArgs
 *                 {
 *                     ProjectId = source[1].Project,
 *                     DatasetId = source[1].DatasetId,
 *                     TableId = source[1].TableId,
 *                 },
 *             },
 *             DestinationTable = new Gcp.BigQuery.Inputs.JobCopyDestinationTableArgs
 *             {
 *                 ProjectId = dest.Project,
 *                 DatasetId = dest.DatasetId,
 *                 TableId = dest.TableId,
 *             },
 *             DestinationEncryptionConfiguration = new Gcp.BigQuery.Inputs.JobCopyDestinationEncryptionConfigurationArgs
 *             {
 *                 KmsKeyName = cryptoKey.Id,
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"fmt"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/bigquery"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/kms"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/organizations"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/projects"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		count := 2
 * 		var sourceDataset []*bigquery.Dataset
 * 		for index := 0; index < count; index++ {
 * 			key0 := index
 * 			val0 := index
 * 			__res, err := bigquery.NewDataset(ctx, fmt.Sprintf("source-%v", key0), &bigquery.DatasetArgs{
 * 				DatasetId:    pulumi.String(fmt.Sprintf("job_copy_%v_dataset", val0)),
 * 				FriendlyName: pulumi.String("test"),
 * 				Description:  pulumi.String("This is a test description"),
 * 				Location:     pulumi.String("US"),
 * 			})
 * 			if err != nil {
 * 				return err
 * 			}
 * 			sourceDataset = append(sourceDataset, __res)
 * 		}
 * 		var source []*bigquery.Table
 * 		for index := 0; index < count; index++ {
 * 			key0 := index
 * 			val0 := index
 * 			__res, err := bigquery.NewTable(ctx, fmt.Sprintf("source-%v", key0), &bigquery.TableArgs{
 * 				DeletionProtection: pulumi.Bool(false),
 * 				DatasetId:          sourceDataset[val0].DatasetId,
 * 				TableId:            pulumi.String(fmt.Sprintf("job_copy_%v_table", val0)),
 * 				Schema: pulumi.String(`[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * `),
 * 			})
 * 			if err != nil {
 * 				return err
 * 			}
 * 			source = append(source, __res)
 * 		}
 * 		destDataset, err := bigquery.NewDataset(ctx, "dest", &bigquery.DatasetArgs{
 * 			DatasetId:    pulumi.String("job_copy_dest_dataset"),
 * 			FriendlyName: pulumi.String("test"),
 * 			Description:  pulumi.String("This is a test description"),
 * 			Location:     pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		keyRing, err := kms.NewKeyRing(ctx, "key_ring", &kms.KeyRingArgs{
 * 			Name:     pulumi.String("example-keyring"),
 * 			Location: pulumi.String("global"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		cryptoKey, err := kms.NewCryptoKey(ctx, "crypto_key", &kms.CryptoKeyArgs{
 * 			Name:    pulumi.String("example-key"),
 * 			KeyRing: keyRing.ID(),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		dest, err := bigquery.NewTable(ctx, "dest", &bigquery.TableArgs{
 * 			DeletionProtection: pulumi.Bool(false),
 * 			DatasetId:          destDataset.DatasetId,
 * 			TableId:            pulumi.String("job_copy_dest_table"),
 * 			Schema: pulumi.String(`[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * `),
 * 			EncryptionConfiguration: &bigquery.TableEncryptionConfigurationArgs{
 * 				KmsKeyName: cryptoKey.ID(),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		project, err := organizations.LookupProject(ctx, &organizations.LookupProjectArgs{
 * 			ProjectId: pulumi.StringRef("my-project-name"),
 * 		}, nil)
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = projects.NewIAMMember(ctx, "encrypt_role", &projects.IAMMemberArgs{
 * 			Project: pulumi.String(project.ProjectId),
 * 			Role:    pulumi.String("roles/cloudkms.cryptoKeyEncrypterDecrypter"),
 * 			Member:  pulumi.String(fmt.Sprintf("serviceAccount:bq-%[email protected]", project.Number)),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewJob(ctx, "job", &bigquery.JobArgs{
 * 			JobId: pulumi.String("job_copy"),
 * 			Copy: &bigquery.JobCopyArgs{
 * 				SourceTables: bigquery.JobCopySourceTableArray{
 * 					&bigquery.JobCopySourceTableArgs{
 * 						ProjectId: source[0].Project,
 * 						DatasetId: source[0].DatasetId,
 * 						TableId:   source[0].TableId,
 * 					},
 * 					&bigquery.JobCopySourceTableArgs{
 * 						ProjectId: source[1].Project,
 * 						DatasetId: source[1].DatasetId,
 * 						TableId:   source[1].TableId,
 * 					},
 * 				},
 * 				DestinationTable: &bigquery.JobCopyDestinationTableArgs{
 * 					ProjectId: dest.Project,
 * 					DatasetId: dest.DatasetId,
 * 					TableId:   dest.TableId,
 * 				},
 * 				DestinationEncryptionConfiguration: &bigquery.JobCopyDestinationEncryptionConfigurationArgs{
 * 					KmsKeyName: cryptoKey.ID(),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.bigquery.Dataset;
 * import com.pulumi.gcp.bigquery.DatasetArgs;
 * import com.pulumi.gcp.bigquery.Table;
 * import com.pulumi.gcp.bigquery.TableArgs;
 * import com.pulumi.gcp.kms.KeyRing;
 * import com.pulumi.gcp.kms.KeyRingArgs;
 * import com.pulumi.gcp.kms.CryptoKey;
 * import com.pulumi.gcp.kms.CryptoKeyArgs;
 * import com.pulumi.gcp.bigquery.inputs.TableEncryptionConfigurationArgs;
 * import com.pulumi.gcp.organizations.OrganizationsFunctions;
 * import com.pulumi.gcp.organizations.inputs.GetProjectArgs;
 * import com.pulumi.gcp.projects.IAMMember;
 * import com.pulumi.gcp.projects.IAMMemberArgs;
 * import com.pulumi.gcp.bigquery.Job;
 * import com.pulumi.gcp.bigquery.JobArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobCopyArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobCopyDestinationTableArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobCopyDestinationEncryptionConfigurationArgs;
 * import com.pulumi.codegen.internal.KeyedValue;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         final var count = 2;
 *         for (var i = 0; i < count; i++) {
 *             new Dataset("sourceDataset-" + i, DatasetArgs.builder()
 *                 .datasetId(String.format("job_copy_%s_dataset", range.value()))
 *                 .friendlyName("test")
 *                 .description("This is a test description")
 *                 .location("US")
 *                 .build());
 * }
 *         for (var i = 0; i < count; i++) {
 *             new Table("source-" + i, TableArgs.builder()
 *                 .deletionProtection(false)
 *                 .datasetId(sourceDataset[range.value()].datasetId())
 *                 .tableId(String.format("job_copy_%s_table", range.value()))
 *                 .schema("""
 * [
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 *                 """)
 *                 .build());
 * }
 *         var destDataset = new Dataset("destDataset", DatasetArgs.builder()
 *             .datasetId("job_copy_dest_dataset")
 *             .friendlyName("test")
 *             .description("This is a test description")
 *             .location("US")
 *             .build());
 *         var keyRing = new KeyRing("keyRing", KeyRingArgs.builder()
 *             .name("example-keyring")
 *             .location("global")
 *             .build());
 *         var cryptoKey = new CryptoKey("cryptoKey", CryptoKeyArgs.builder()
 *             .name("example-key")
 *             .keyRing(keyRing.id())
 *             .build());
 *         var dest = new Table("dest", TableArgs.builder()
 *             .deletionProtection(false)
 *             .datasetId(destDataset.datasetId())
 *             .tableId("job_copy_dest_table")
 *             .schema("""
 * [
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 *             """)
 *             .encryptionConfiguration(TableEncryptionConfigurationArgs.builder()
 *                 .kmsKeyName(cryptoKey.id())
 *                 .build())
 *             .build());
 *         final var project = OrganizationsFunctions.getProject(GetProjectArgs.builder()
 *             .projectId("my-project-name")
 *             .build());
 *         var encryptRole = new IAMMember("encryptRole", IAMMemberArgs.builder()
 *             .project(project.applyValue(getProjectResult -> getProjectResult.projectId()))
 *             .role("roles/cloudkms.cryptoKeyEncrypterDecrypter")
 *             .member(String.format("serviceAccount:bq-%[email protected]", project.applyValue(getProjectResult -> getProjectResult.number())))
 *             .build());
 *         var job = new Job("job", JobArgs.builder()
 *             .jobId("job_copy")
 *             .copy(JobCopyArgs.builder()
 *                 .sourceTables(
 *                     JobCopySourceTableArgs.builder()
 *                         .projectId(source[0].project())
 *                         .datasetId(source[0].datasetId())
 *                         .tableId(source[0].tableId())
 *                         .build(),
 *                     JobCopySourceTableArgs.builder()
 *                         .projectId(source[1].project())
 *                         .datasetId(source[1].datasetId())
 *                         .tableId(source[1].tableId())
 *                         .build())
 *                 .destinationTable(JobCopyDestinationTableArgs.builder()
 *                     .projectId(dest.project())
 *                     .datasetId(dest.datasetId())
 *                     .tableId(dest.tableId())
 *                     .build())
 *                 .destinationEncryptionConfiguration(JobCopyDestinationEncryptionConfigurationArgs.builder()
 *                     .kmsKeyName(cryptoKey.id())
 *                     .build())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * 
 * ### Bigquery Job Extract
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as gcp from "@pulumi/gcp";
 * const source_oneDataset = new gcp.bigquery.Dataset("source-one", {
 *     datasetId: "job_extract_dataset",
 *     friendlyName: "test",
 *     description: "This is a test description",
 *     location: "US",
 * });
 * const source_one = new gcp.bigquery.Table("source-one", {
 *     deletionProtection: false,
 *     datasetId: source_oneDataset.datasetId,
 *     tableId: "job_extract_table",
 *     schema: `[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * `,
 * });
 * const dest = new gcp.storage.Bucket("dest", {
 *     name: "job_extract_bucket",
 *     location: "US",
 *     forceDestroy: true,
 * });
 * const job = new gcp.bigquery.Job("job", {
 *     jobId: "job_extract",
 *     extract: {
 *         destinationUris: [pulumi.interpolate`${dest.url}/extract`],
 *         sourceTable: {
 *             projectId: source_one.project,
 *             datasetId: source_one.datasetId,
 *             tableId: source_one.tableId,
 *         },
 *         destinationFormat: "NEWLINE_DELIMITED_JSON",
 *         compression: "GZIP",
 *     },
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_gcp as gcp
 * source_one_dataset = gcp.bigquery.Dataset("source-one",
 *     dataset_id="job_extract_dataset",
 *     friendly_name="test",
 *     description="This is a test description",
 *     location="US")
 * source_one = gcp.bigquery.Table("source-one",
 *     deletion_protection=False,
 *     dataset_id=source_one_dataset.dataset_id,
 *     table_id="job_extract_table",
 *     schema="""[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * """)
 * dest = gcp.storage.Bucket("dest",
 *     name="job_extract_bucket",
 *     location="US",
 *     force_destroy=True)
 * job = gcp.bigquery.Job("job",
 *     job_id="job_extract",
 *     extract=gcp.bigquery.JobExtractArgs(
 *         destination_uris=[dest.url.apply(lambda url: f"{url}/extract")],
 *         source_table=gcp.bigquery.JobExtractSourceTableArgs(
 *             project_id=source_one.project,
 *             dataset_id=source_one.dataset_id,
 *             table_id=source_one.table_id,
 *         ),
 *         destination_format="NEWLINE_DELIMITED_JSON",
 *         compression="GZIP",
 *     ))
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Gcp = Pulumi.Gcp;
 * return await Deployment.RunAsync(() =>
 * {
 *     var source_oneDataset = new Gcp.BigQuery.Dataset("source-one", new()
 *     {
 *         DatasetId = "job_extract_dataset",
 *         FriendlyName = "test",
 *         Description = "This is a test description",
 *         Location = "US",
 *     });
 *     var source_one = new Gcp.BigQuery.Table("source-one", new()
 *     {
 *         DeletionProtection = false,
 *         DatasetId = source_oneDataset.DatasetId,
 *         TableId = "job_extract_table",
 *         Schema = @"[
 *   {
 *     ""name"": ""name"",
 *     ""type"": ""STRING"",
 *     ""mode"": ""NULLABLE""
 *   },
 *   {
 *     ""name"": ""post_abbr"",
 *     ""type"": ""STRING"",
 *     ""mode"": ""NULLABLE""
 *   },
 *   {
 *     ""name"": ""date"",
 *     ""type"": ""DATE"",
 *     ""mode"": ""NULLABLE""
 *   }
 * ]
 * ",
 *     });
 *     var dest = new Gcp.Storage.Bucket("dest", new()
 *     {
 *         Name = "job_extract_bucket",
 *         Location = "US",
 *         ForceDestroy = true,
 *     });
 *     var job = new Gcp.BigQuery.Job("job", new()
 *     {
 *         JobId = "job_extract",
 *         Extract = new Gcp.BigQuery.Inputs.JobExtractArgs
 *         {
 *             DestinationUris = new[]
 *             {
 *                 dest.Url.Apply(url => $"{url}/extract"),
 *             },
 *             SourceTable = new Gcp.BigQuery.Inputs.JobExtractSourceTableArgs
 *             {
 *                 ProjectId = source_one.Project,
 *                 DatasetId = source_one.DatasetId,
 *                 TableId = source_one.TableId,
 *             },
 *             DestinationFormat = "NEWLINE_DELIMITED_JSON",
 *             Compression = "GZIP",
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"fmt"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/bigquery"
 * 	"github.com/pulumi/pulumi-gcp/sdk/v7/go/gcp/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		_, err := bigquery.NewDataset(ctx, "source-one", &bigquery.DatasetArgs{
 * 			DatasetId:    pulumi.String("job_extract_dataset"),
 * 			FriendlyName: pulumi.String("test"),
 * 			Description:  pulumi.String("This is a test description"),
 * 			Location:     pulumi.String("US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewTable(ctx, "source-one", &bigquery.TableArgs{
 * 			DeletionProtection: pulumi.Bool(false),
 * 			DatasetId:          source_oneDataset.DatasetId,
 * 			TableId:            pulumi.String("job_extract_table"),
 * 			Schema: pulumi.String(`[
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 * `),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		dest, err := storage.NewBucket(ctx, "dest", &storage.BucketArgs{
 * 			Name:         pulumi.String("job_extract_bucket"),
 * 			Location:     pulumi.String("US"),
 * 			ForceDestroy: pulumi.Bool(true),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = bigquery.NewJob(ctx, "job", &bigquery.JobArgs{
 * 			JobId: pulumi.String("job_extract"),
 * 			Extract: &bigquery.JobExtractArgs{
 * 				DestinationUris: pulumi.StringArray{
 * 					dest.Url.ApplyT(func(url string) (string, error) {
 * 						return fmt.Sprintf("%v/extract", url), nil
 * 					}).(pulumi.StringOutput),
 * 				},
 * 				SourceTable: &bigquery.JobExtractSourceTableArgs{
 * 					ProjectId: source_one.Project,
 * 					DatasetId: source_one.DatasetId,
 * 					TableId:   source_one.TableId,
 * 				},
 * 				DestinationFormat: pulumi.String("NEWLINE_DELIMITED_JSON"),
 * 				Compression:       pulumi.String("GZIP"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.gcp.bigquery.Dataset;
 * import com.pulumi.gcp.bigquery.DatasetArgs;
 * import com.pulumi.gcp.bigquery.Table;
 * import com.pulumi.gcp.bigquery.TableArgs;
 * import com.pulumi.gcp.storage.Bucket;
 * import com.pulumi.gcp.storage.BucketArgs;
 * import com.pulumi.gcp.bigquery.Job;
 * import com.pulumi.gcp.bigquery.JobArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobExtractArgs;
 * import com.pulumi.gcp.bigquery.inputs.JobExtractSourceTableArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var source_oneDataset = new Dataset("source-oneDataset", DatasetArgs.builder()
 *             .datasetId("job_extract_dataset")
 *             .friendlyName("test")
 *             .description("This is a test description")
 *             .location("US")
 *             .build());
 *         var source_one = new Table("source-one", TableArgs.builder()
 *             .deletionProtection(false)
 *             .datasetId(source_oneDataset.datasetId())
 *             .tableId("job_extract_table")
 *             .schema("""
 * [
 *   {
 *     "name": "name",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "post_abbr",
 *     "type": "STRING",
 *     "mode": "NULLABLE"
 *   },
 *   {
 *     "name": "date",
 *     "type": "DATE",
 *     "mode": "NULLABLE"
 *   }
 * ]
 *             """)
 *             .build());
 *         var dest = new Bucket("dest", BucketArgs.builder()
 *             .name("job_extract_bucket")
 *             .location("US")
 *             .forceDestroy(true)
 *             .build());
 *         var job = new Job("job", JobArgs.builder()
 *             .jobId("job_extract")
 *             .extract(JobExtractArgs.builder()
 *                 .destinationUris(dest.url().applyValue(url -> String.format("%s/extract", url)))
 *                 .sourceTable(JobExtractSourceTableArgs.builder()
 *                     .projectId(source_one.project())
 *                     .datasetId(source_one.datasetId())
 *                     .tableId(source_one.tableId())
 *                     .build())
 *                 .destinationFormat("NEWLINE_DELIMITED_JSON")
 *                 .compression("GZIP")
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * ```yaml
 * resources:
 *   source-one:
 *     type: gcp:bigquery:Table
 *     properties:
 *       deletionProtection: false
 *       datasetId: ${["source-oneDataset"].datasetId}
 *       tableId: job_extract_table
 *       schema: |
 *         [
 *           {
 *             "name": "name",
 *             "type": "STRING",
 *             "mode": "NULLABLE"
 *           },
 *           {
 *             "name": "post_abbr",
 *             "type": "STRING",
 *             "mode": "NULLABLE"
 *           },
 *           {
 *             "name": "date",
 *             "type": "DATE",
 *             "mode": "NULLABLE"
 *           }
 *         ]
 *   source-oneDataset:
 *     type: gcp:bigquery:Dataset
 *     name: source-one
 *     properties:
 *       datasetId: job_extract_dataset
 *       friendlyName: test
 *       description: This is a test description
 *       location: US
 *   dest:
 *     type: gcp:storage:Bucket
 *     properties:
 *       name: job_extract_bucket
 *       location: US
 *       forceDestroy: true
 *   job:
 *     type: gcp:bigquery:Job
 *     properties:
 *       jobId: job_extract
 *       extract:
 *         destinationUris:
 *           - ${dest.url}/extract
 *         sourceTable:
 *           projectId: ${["source-one"].project}
 *           datasetId: ${["source-one"].datasetId}
 *           tableId: ${["source-one"].tableId}
 *         destinationFormat: NEWLINE_DELIMITED_JSON
 *         compression: GZIP
 * ```
 * 
 * ## Import
 * Job can be imported using any of these accepted formats:
 * * `projects/{{project}}/jobs/{{job_id}}/location/{{location}}`
 * * `projects/{{project}}/jobs/{{job_id}}`
 * * `{{project}}/{{job_id}}/{{location}}`
 * * `{{job_id}}/{{location}}`
 * * `{{project}}/{{job_id}}`
 * * `{{job_id}}`
 * When using the `pulumi import` command, Job can be imported using one of the formats above. For example:
 * ```sh
 * $ pulumi import gcp:bigquery/job:Job default projects/{{project}}/jobs/{{job_id}}/location/{{location}}
 * ```
 * ```sh
 * $ pulumi import gcp:bigquery/job:Job default projects/{{project}}/jobs/{{job_id}}
 * ```
 * ```sh
 * $ pulumi import gcp:bigquery/job:Job default {{project}}/{{job_id}}/{{location}}
 * ```
 * ```sh
 * $ pulumi import gcp:bigquery/job:Job default {{job_id}}/{{location}}
 * ```
 * ```sh
 * $ pulumi import gcp:bigquery/job:Job default {{project}}/{{job_id}}
 * ```
 * ```sh
 * $ pulumi import gcp:bigquery/job:Job default {{job_id}}
 * ```
 */
public class Job internal constructor(
    override val javaResource: com.pulumi.gcp.bigquery.Job,
) : KotlinCustomResource(javaResource, JobMapper) {
    /**
     * Copies a table.
     */
    public val copy: Output?
        get() = javaResource.copy().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    jobCopyToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * (Output)
     * All of labels (key/value pairs) present on the resource in GCP, including the labels configured through Pulumi, other clients and services.
     */
    public val effectiveLabels: Output>
        get() = javaResource.effectiveLabels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.key.to(args0.value)
            }).toMap()
        })

    /**
     * Configures an extract job.
     */
    public val extract: Output?
        get() = javaResource.extract().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    jobExtractToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * The ID of the job. The ID must contain only letters (a-z, A-Z), numbers (0-9), underscores (_), or dashes (-). The maximum length is 1,024 characters.
     */
    public val jobId: Output
        get() = javaResource.jobId().applyValue({ args0 -> args0 })

    /**
     * Job timeout in milliseconds. If this time limit is exceeded, BigQuery may attempt to terminate the job.
     */
    public val jobTimeoutMs: Output?
        get() = javaResource.jobTimeoutMs().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * (Output)
     * The type of the job.
     */
    public val jobType: Output
        get() = javaResource.jobType().applyValue({ args0 -> args0 })

    /**
     * The labels associated with this job. You can use these to organize and group your jobs. **Note**: This field is
     * non-authoritative, and will only manage the labels present in your configuration. Please refer to the field
     * 'effective_labels' for all of the labels present on the resource.
     */
    public val labels: Output>?
        get() = javaResource.labels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.key.to(args0.value)
                }).toMap()
            }).orElse(null)
        })

    /**
     * Configures a load job.
     */
    public val load: Output?
        get() = javaResource.load().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    jobLoadToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * Specifies where the error occurred, if present.
     */
    public val location: Output?
        get() = javaResource.location().applyValue({ args0 -> args0.map({ args0 -> args0 }).orElse(null) })

    public val project: Output
        get() = javaResource.project().applyValue({ args0 -> args0 })

    /**
     * (Output)
     * The combination of labels configured directly on the resource
     * and default labels configured on the provider.
     */
    public val pulumiLabels: Output>
        get() = javaResource.pulumiLabels().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.key.to(args0.value)
            }).toMap()
        })

    /**
     * Configures a query job.
     */
    public val query: Output?
        get() = javaResource.query().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    jobQueryToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * The status of this job. Examine this value when polling an asynchronous job to see if the job is complete.
     * Structure is documented below.
     */
    public val statuses: Output>
        get() = javaResource.statuses().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    jobStatusToKotlin(args0)
                })
            })
        })

    /**
     * Email address of the user who ran the job.
     */
    public val userEmail: Output
        get() = javaResource.userEmail().applyValue({ args0 -> args0 })
}

public object JobMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.gcp.bigquery.Job::class == javaResource::class

    override fun map(javaResource: Resource): Job = Job(javaResource as com.pulumi.gcp.bigquery.Job)
}

/**
 * @see [Job].
 * @param name The _unique_ name of the resulting resource.
 * @param block Builder for [Job].
 */
public suspend fun job(name: String, block: suspend JobResourceBuilder.() -> Unit): Job {
    val builder = JobResourceBuilder()
    builder.name(name)
    block(builder)
    return builder.build()
}

/**
 * @see [Job].
 * @param name The _unique_ name of the resulting resource.
 */
public fun job(name: String): Job {
    val builder = JobResourceBuilder()
    builder.name(name)
    return builder.build()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy