create a snapshot of a BigQuery table
Stay organized with collections
Save and categorize content based on your preferences.
Demonstrates creating a snapshot table from a managed BigQuery table.
Code sample
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],[],[[["\u003cp\u003eThis content demonstrates how to create a snapshot table from an existing managed BigQuery table.\u003c/p\u003e\n"],["\u003cp\u003eThe provided Python code sample utilizes the \u003ccode\u003egoogle.cloud.bigquery\u003c/code\u003e library to create the snapshot.\u003c/p\u003e\n"],["\u003cp\u003eSetting up Application Default Credentials is required for authenticating to BigQuery before running the code.\u003c/p\u003e\n"],["\u003cp\u003eThe process involves specifying the source table ID and the desired snapshot table ID within the code.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003ebigquery.OperationType.SNAPSHOT\u003c/code\u003e is used to identify the operation as creating a snapshot when configuring the copy job.\u003c/p\u003e\n"]]],[],null,["# create a snapshot of a BigQuery table\n\nDemonstrates creating a snapshot table from a managed BigQuery table.\n\nCode sample\n-----------\n\n### Python\n\n\nBefore trying this sample, follow the Python setup instructions in the\n[BigQuery quickstart using\nclient libraries](/bigquery/docs/quickstarts/quickstart-client-libraries).\n\n\nFor more information, see the\n[BigQuery Python API\nreference documentation](/python/docs/reference/bigquery/latest).\n\n\nTo authenticate to BigQuery, set up Application Default Credentials.\nFor more information, see\n\n[Set up authentication for client libraries](/bigquery/docs/authentication#client-libs).\n\n from google.cloud import https://cloud.google.com/python/docs/reference/bigquery/latest/\n\n # TODO(developer): Set table_id to the ID of the table to create.\n source_table_id = \"your-project.your_dataset.your_table_name\"\n snapshot_table_id = \"your-project.your_dataset.snapshot_table_name\"\n\n # Construct a BigQuery client object.\n client = https://cloud.google.com/python/docs/reference/bigquery/latest/.https://cloud.google.com/python/docs/reference/bigquery/latest/google.cloud.bigquery.client.Client.html()\n copy_config = https://cloud.google.com/python/docs/reference/bigquery/latest/.https://cloud.google.com/python/docs/reference/bigquery/latest/google.cloud.bigquery.job.CopyJobConfig.html()\n copy_config.https://cloud.google.com/python/docs/reference/bigquery/latest/google.cloud.bigquery.job.CopyJobConfig.html#google_cloud_bigquery_job_CopyJobConfig_operation_type = https://cloud.google.com/python/docs/reference/bigquery/latest/.https://cloud.google.com/python/docs/reference/bigquery/latest/google.cloud.bigquery.job.OperationType.html.https://cloud.google.com/python/docs/reference/bigquery/latest/google.cloud.bigquery.job.OperationType.html#google_cloud_bigquery_job_OperationType_SNAPSHOT\n\n copy_job = client.https://cloud.google.com/python/docs/reference/bigquery/latest/google.cloud.bigquery.client.Client.html#google_cloud_bigquery_client_Client_copy_table(\n sources=source_table_id,\n destination=snapshot_table_id,\n job_config=copy_config,\n )\n copy_job.result()\n\n print(\"Created table snapshot {}\".format(snapshot_table_id))\n\nWhat's next\n-----------\n\n\nTo search and filter code samples for other Google Cloud products, see the\n[Google Cloud sample browser](/docs/samples?product=bigquery)."]]