BigQuery 中的 SQL 簡介

本文將概略介紹 BigQuery 支援的陳述式和 SQL 方言。

GoogleSQL 是符合 ANSI 標準的 結構化查詢語言 (SQL),包含下列支援的陳述式類型:

BigQuery SQL 方言

BigQuery 支援 GoogleSQL 方言,但也支援舊版 SQL 方言。如果您是 BigQuery 新手,建議使用 GoogleSQL,因為這項服務支援最廣泛的功能。舉例來說,DDL 和 DML 陳述式等功能僅支援使用 GoogleSQL。舊版 SQL 是為了向後相容性而維護,如果客戶使用舊版 SQL,我們建議遷移

變更為使用非預設方言

您用來查詢資料的介面會決定哪一種查詢方言為預設方言。如要切換至其他方言,請執行下列操作:

Google Cloud 主控台的預設方言為 GoogleSQL。如要將方言變更為舊版 SQL,請執行下列操作:

  1. 前往 Google Cloud 控制台的「BigQuery」頁面。

    前往 BigQuery

  2. 在查詢編輯器中,依序按一下「More」>「Query settings」按鈕。

  3. 在「Advanced options」部分的「SQL dialect」中,點選「Legacy」,然後點選「Save」。這會為此查詢設定舊版 SQL 選項。按一下 add_box SQL 查詢建立新查詢時,必須再次選取舊版 SQL 選項。

預設的 SQL 方言為 GoogleSQL。您可以將前置字串 #standardSQL#legacySQL 加入查詢中,藉此設定 SQL 方言。這些查詢前置字串不區分大小寫,必須放在查詢之前,且必須以換行字元與查詢分隔。以下範例將方言設為舊版 SQL,並查詢出生率資料集:

  1. 前往 Google Cloud 控制台的「BigQuery」頁面。

    前往 BigQuery

  2. 在查詢編輯器中輸入以下陳述式:

    #legacySQL
    SELECT
      weight_pounds, state, year, gestation_weeks
    FROM
      [bigquery-public-data:samples.natality]
    ORDER BY
      weight_pounds DESC
    LIMIT
      10;

  3. 按一下 「Run」

如要進一步瞭解如何執行查詢,請參閱「執行互動式查詢」一文。

bq 指令列工具中的預設查詢方言為舊版 SQL。如要切換成 GoogleSQL 方言,請在指令列陳述式中加入 --use_legacy_sql=false--nouse_legacy_sql 旗標。

改用 GoogleSQL 方言

如要在查詢工作中使用 GoogleSQL 語法,請將 use_legacy_sql 參數設為 false

  bq query \
  --use_legacy_sql=false \
  'SELECT
    word
  FROM
    `bigquery-public-data.samples.shakespeare`'

將 GoogleSQL 設為預設方言

如要將 GoogleSQL 設為指令列工具和互動殼層的預設方言,您可以編輯指令列工具的設定檔 .bigqueryrc

如要進一步瞭解 .bigqueryrc,請參閱設定指令專屬旗標預設值的相關說明。

如要在 .bigqueryrc 中設定 --use_legacy_sql=false,請執行下列操作:

  1. 在文字編輯器中開啟 .bigqueryrc。根據預設,.bigqueryrc 應位於您的使用者目錄中,例如 $HOME/.bigqueryrc
  2. 在檔案中加入以下文字。本範例會將查詢和 mk 指令 (用於建立檢視表) 的預設語法設為 GoogleSQL。如果您已為 querymk 指令旗標設定了預設值,則不必重新加入 [query][mk]

    [query]
    --use_legacy_sql=false
    [mk]
    --use_legacy_sql=false
    
  3. 儲存並關閉檔案。

  4. 如果您使用的是互動殼層,則必須退出並重新啟動殼層,變更才會生效。

如要瞭解可用的指令列旗標,請參閱 bq 指令列工具參考資料

在嘗試這個範例之前,請先按照 BigQuery 快速入門:使用用戶端程式庫中的 C# 設定說明進行操作。詳情請參閱 BigQuery C# API 參考說明文件

如要向 BigQuery 進行驗證,請設定應用程式預設憑證。詳情請參閱「設定用戶端程式庫的驗證機制」。

預設情況下,C# 程式庫會使用 GoogleSQL。

切換至舊版 SQL 方言

如要在查詢工作中使用舊版 SQL 語法,請將 UseLegacySql 參數設為 true


using Google.Cloud.BigQuery.V2;
using System;

public class BigQueryQueryLegacy
{
    public void QueryLegacy(
        string projectId = "your-project-id"
    )
    {
        BigQueryClient client = BigQueryClient.Create(projectId);
        string query = @"
            SELECT name FROM [bigquery-public-data:usa_names.usa_1910_2013]
            WHERE state = 'TX'
            LIMIT 100";
        BigQueryJob job = client.CreateQueryJob(
            sql: query,
            parameters: null,
            options: new QueryOptions { UseLegacySql = true });
        // Wait for the job to complete.
        job = job.PollUntilCompleted().ThrowOnAnyError();
        // Display the results
        foreach (BigQueryRow row in client.GetQueryResults(job.Reference))
        {
            Console.WriteLine($"{row["name"]}");
        }
    }
}

在嘗試這個範例之前,請先按照 BigQuery 快速入門:使用用戶端程式庫中的 Go 設定說明進行操作。詳情請參閱 BigQuery Go API 參考說明文件

如要向 BigQuery 進行驗證,請設定應用程式預設憑證。詳情請參閱「設定用戶端程式庫的驗證機制」。

根據預設,Go 用戶端程式庫會使用 GoogleSQL。

切換至舊版 SQL 方言

如要在查詢工作中使用舊版 SQL 語法,請將查詢設定中的 UseLegacySQL 屬性設為 true

import (
	"context"
	"fmt"
	"io"

	"cloud.google.com/go/bigquery"
	"google.golang.org/api/iterator"
)

// queryLegacy demonstrates running a query using Legacy SQL.
func queryLegacy(w io.Writer, projectID, sqlString string) error {
	// projectID := "my-project-id"
	// sqlString = "SELECT 3 as somenum"
	ctx := context.Background()
	client, err := bigquery.NewClient(ctx, projectID)
	if err != nil {
		return fmt.Errorf("bigquery.NewClient: %w", err)
	}
	defer client.Close()

	q := client.Query(sqlString)
	q.UseLegacySQL = true

	// Run the query and process the returned row iterator.
	it, err := q.Read(ctx)
	if err != nil {
		return fmt.Errorf("query.Read(): %w", err)
	}
	for {
		var row []bigquery.Value
		err := it.Next(&row)
		if err == iterator.Done {
			break
		}
		if err != nil {
			return err
		}
		fmt.Fprintln(w, row)
	}
	return nil
}

在嘗試這個範例之前,請先按照 BigQuery 快速入門:使用用戶端程式庫中的 Java 設定說明進行操作。詳情請參閱 BigQuery Java API 參考說明文件

如要向 BigQuery 進行驗證,請設定應用程式預設憑證。詳情請參閱「設定用戶端程式庫的驗證機制」。

根據預設,Java 用戶端程式庫會使用 GoogleSQL。

切換至舊版 SQL 方言

如要在查詢工作中使用舊版 SQL 語法,請將 useLegacySql 參數設為 true

import com.google.cloud.bigquery.BigQuery;
import com.google.cloud.bigquery.BigQueryException;
import com.google.cloud.bigquery.BigQueryOptions;
import com.google.cloud.bigquery.QueryJobConfiguration;
import com.google.cloud.bigquery.TableResult;

public class RunLegacyQuery {

  public static void main(String[] args) {
    runLegacyQuery();
  }

  public static void runLegacyQuery() {
    try {
      // Initialize client that will be used to send requests. This client only needs to be created
      // once, and can be reused for multiple requests.
      BigQuery bigquery = BigQueryOptions.getDefaultInstance().getService();

      // To use legacy SQL syntax, set useLegacySql to true.
      String query =
          "SELECT corpus FROM [bigquery-public-data:samples.shakespeare] GROUP BY corpus;";
      QueryJobConfiguration queryConfig =
          QueryJobConfiguration.newBuilder(query).setUseLegacySql(true).build();

      // Execute the query.
      TableResult result = bigquery.query(queryConfig);

      // Print the results.
      result.iterateAll().forEach(rows -> rows.forEach(row -> System.out.println(row.getValue())));

      System.out.println("Legacy query ran successfully");
    } catch (BigQueryException | InterruptedException e) {
      System.out.println("Legacy query did not run \n" + e.toString());
    }
  }
}

在嘗試這個範例之前,請先按照 BigQuery 快速入門:使用用戶端程式庫中的 Node.js 設定說明進行操作。詳情請參閱 BigQuery Node.js API 參考說明文件

如要向 BigQuery 進行驗證,請設定應用程式預設憑證。詳情請參閱「設定用戶端程式庫的驗證機制」。

Node.js 用戶端程式庫預設使用 GoogleSQL。

切換至舊版 SQL 方言

如要在查詢工作中使用舊版 SQL 語法,請將 useLegacySql 參數設為 true

// Import the Google Cloud client library
const {BigQuery} = require('@google-cloud/bigquery');
const bigquery = new BigQuery();

async function queryLegacy() {
  // Queries the U.S. given names dataset for the state of Texas using legacy SQL.

  const query =
    'SELECT word FROM [bigquery-public-data:samples.shakespeare] LIMIT 10;';

  // For all options, see https://cloud.google.com/bigquery/docs/reference/rest/v2/jobs/query
  const options = {
    query: query,
    // Location must match that of the dataset(s) referenced in the query.
    location: 'US',
    useLegacySql: true,
  };

  // Run the query as a job
  const [job] = await bigquery.createQueryJob(options);
  console.log(`Job ${job.id} started.`);

  // Wait for the query to finish
  const [rows] = await job.getQueryResults();

  // Print the results
  console.log('Rows:');
  rows.forEach(row => console.log(row));
}

在嘗試這個範例之前,請先按照 BigQuery 快速入門:使用用戶端程式庫中的 PHP 設定說明進行操作。詳情請參閱 BigQuery PHP API 參考說明文件

如要向 BigQuery 進行驗證,請設定應用程式預設憑證。詳情請參閱「設定用戶端程式庫的驗證機制」。

根據預設,PHP 用戶端程式庫會使用 GoogleSQL。

切換至舊版 SQL 方言

如要在查詢工作中使用舊版 SQL 語法,請將 useLegacySql 參數設為 true

use Google\Cloud\BigQuery\BigQueryClient;

/**
 * Query using legacy sql
 *
 * @param string $projectId The project Id of your Google Cloud Project.
 */
function query_legacy(string $projectId): void
{
    $query = 'SELECT corpus FROM [bigquery-public-data:samples.shakespeare] GROUP BY corpus';

    $bigQuery = new BigQueryClient([
      'projectId' => $projectId,
    ]);
    $jobConfig = $bigQuery->query($query)->useLegacySql(true);

    $queryResults = $bigQuery->runQuery($jobConfig);

    $i = 0;
    foreach ($queryResults as $row) {
        printf('--- Row %s ---' . PHP_EOL, ++$i);
        foreach ($row as $column => $value) {
            printf('%s: %s' . PHP_EOL, $column, json_encode($value));
        }
    }
    printf('Found %s row(s)' . PHP_EOL, $i);
}

在嘗試這個範例之前,請先按照 BigQuery 快速入門:使用用戶端程式庫中的 Python 設定說明進行操作。詳情請參閱 BigQuery Python API 參考說明文件

如要向 BigQuery 進行驗證,請設定應用程式預設憑證。詳情請參閱「設定用戶端程式庫的驗證機制」。

根據預設,Python 用戶端程式庫會使用 GoogleSQL。

切換至舊版 SQL 方言

如要在查詢工作中使用舊版 SQL 語法,請將 use_legacy_sql 參數設為 True

from google.cloud import bigquery

# Construct a BigQuery client object.
client = bigquery.Client()

query = (
    "SELECT name FROM [bigquery-public-data:usa_names.usa_1910_2013] "
    'WHERE state = "TX" '
    "LIMIT 100"
)

# Set use_legacy_sql to True to use legacy SQL syntax.
job_config = bigquery.QueryJobConfig(use_legacy_sql=True)

# Start the query and waits for query job to complete, passing in the extra configuration.
results = client.query_and_wait(
    query, job_config=job_config
)  # Make an API request.

print("The query data:")
for row in results:
    print(row)

在嘗試這個範例之前,請先按照 BigQuery 快速入門:使用用戶端程式庫中的 Ruby 設定說明進行操作。詳情請參閱 BigQuery Ruby API 參考說明文件

如要向 BigQuery 進行驗證,請設定應用程式預設憑證。詳情請參閱「設定用戶端程式庫的驗證機制」。

根據預設,Ruby 用戶端程式庫會使用 GoogleSQL。

切換至舊版 SQL 方言

如要在查詢工作中使用舊版 SQL 語法,請將 legacy_sql: true 選項傳遞至查詢。

require "google/cloud/bigquery"

def query_legacy
  bigquery = Google::Cloud::Bigquery.new
  sql = "SELECT name FROM [bigquery-public-data:usa_names.usa_1910_2013] " \
        "WHERE state = 'TX' " \
        "LIMIT 100"

  results = bigquery.query sql, legacy_sql: true do |config|
    # Location must match that of the dataset(s) referenced in the query.
    config.location = "US"
  end

  results.each do |row|
    puts row.inspect
  end
end

後續步驟