gcs Табличная Функция
Предоставляет интерфейс, похожий на таблицу, для SELECT
и INSERT
данных из Google Cloud Storage. Требуется роль IAM Storage Object User
.
Это псевдоним для s3 табличной функции.
Если у вас есть несколько реплик в вашем кластере, вы можете использовать функцию s3Cluster (которая работает с GCS) для параллелизации вставок.
Синтаксис
Табличная функция GCS интегрируется с Google Cloud Storage, используя GCS XML API и HMAC ключи. Смотрите документацию о совместимости Google для получения дополнительных сведений об конечной точке и HMAC.
Аргументы
Аргумент | Описание |
---|---|
url | Путь к файлу в корзине. Поддерживает следующие подстановочные знаки в режиме только для чтения: * , ** , ? , {abc,def} и {N..M} , где N , M — числа, а 'abc' , 'def' — строки. |
NOSIGN | Если это ключевое слово указано вместо учетных данных, все запросы не будут подписаны. |
hmac_key и hmac_secret | Ключи, которые указывают учетные данные, используемые с данной конечной точкой. Необязательно. |
format | формат файла. |
structure | Структура таблицы. Формат 'column1_name column1_type, column2_name column2_type, ...' . |
compression_method | Параметр является необязательным. Поддерживаемые значения: none , gzip или gz , brotli или br , xz или LZMA , zstd или zst . По умолчанию метод сжатия будет автоматически определён по расширению файла. |
GCS путь имеет такой формат, так как конечная точка для Google XML API отличается от JSON API:
Аргументы также могут быть переданы с использованием именованных коллекций. В этом случае url
, format
, structure
, compression_method
работают так же, а также поддерживаются некоторые дополнительные параметры:
Параметр | Описание |
---|---|
access_key_id | hmac_key , необязательно. |
secret_access_key | hmac_secret , необязательно. |
filename | Добавляется к url, если указан. |
use_environment_credentials | Включено по умолчанию, позволяет передавать дополнительные параметры с использованием переменных окружения AWS_CONTAINER_CREDENTIALS_RELATIVE_URI , AWS_CONTAINER_CREDENTIALS_FULL_URI , AWS_CONTAINER_AUTHORIZATION_TOKEN , AWS_EC2_METADATA_DISABLED . |
no_sign_request | Отключено по умолчанию. |
expiration_window_seconds | Значение по умолчанию — 120. |
Возвращаемое значение
Таблица с заданной структурой для чтения или записи данных в указанный файл.
Примеры
Выбор первых двух строк из таблицы из GCS файла https://storage.googleapis.com/my-test-bucket-768/data.csv
:
Подобный запрос, но из файла с методом сжатия gzip
:
Использование
Предположим, у нас есть несколько файлов с следующими URI на GCS:
- 'https://storage.googleapis.com/my-test-bucket-768/some_prefix/some_file_1.csv'
- 'https://storage.googleapis.com/my-test-bucket-768/some_prefix/some_file_2.csv'
- 'https://storage.googleapis.com/my-test-bucket-768/some_prefix/some_file_3.csv'
- 'https://storage.googleapis.com/my-test-bucket-768/some_prefix/some_file_4.csv'
- 'https://storage.googleapis.com/my-test-bucket-768/another_prefix/some_file_1.csv'
- 'https://storage.googleapis.com/my-test-bucket-768/another_prefix/some_file_2.csv'
- 'https://storage.googleapis.com/my-test-bucket-768/another_prefix/some_file_3.csv'
- 'https://storage.googleapis.com/my-test-bucket-768/another_prefix/some_file_4.csv'
Подсчитайте количество строк в файлах, заканчивающихся цифрами от 1 до 3:
Подсчитайте общее количество строк во всех файлах в этих двух директориях:
Если ваш список файлов содержит диапазоны чисел с ведущими нулями, используйте конструкцию с фигурными скобками для каждой цифры отдельно или используйте ?
.
Подсчитайте общее количество строк в файлах с именами file-000.csv
, file-001.csv
, ... , file-999.csv
:
Вставьте данные в файл test-data.csv.gz
:
Вставьте данные в файл test-data.csv.gz
из существующей таблицы:
Глобальный поисковый запрос ** может использоваться для рекурсивного обхода директорий. Рассмотрим следующий пример, он извлечет все файлы из директории my-test-bucket-768
рекурсивно:
Следующий запрос получит данные из всех файлов test-data.csv.gz
из любой папки внутри директории my-test-bucket
рекурсивно:
Для производственных случаев использования рекомендуется использовать именованные коллекции. Вот пример:
Разделённая Запись
Если вы укажете выражение PARTITION BY
при вставке данных в таблицу GCS
, будет создан отдельный файл для каждого значения партиции. Разделение данных на отдельные файлы помогает улучшить эффективность операций чтения.
Примеры
- Использование ID партиции в ключе создает отдельные файлы:
В результате данные записываются в три файла: file_x.csv
, file_y.csv
и file_z.csv
.
- Использование ID партиции в имени корзины создает файлы в разных корзинах:
В результате данные записываются в три файла в разных корзинах: my_bucket_1/file.csv
, my_bucket_10/file.csv
и my_bucket_20/file.csv
.