Skip to content

CREATE STAGE

语法说明

CREATE STAGE 用于提供一种高效、安全的方式来与外部存储(如 Amazon S3、文件系统)进行数据交互。通过创建一个外部 Stage,MatrixOne 可以从外部存储中读取文件,并将其快速加载到 MatrixOne 数据库表中。例如,将 Amazon S3 上的 CSV 文件加载到表中。

目前支持以下外部存储:

  • Amazon S3
  • MinIO
  • File System

语法结构

> CREATE STAGE [ IF NOT EXISTS ] { stage_name }
   { StageParams }
   [ COMMENT = '<string_literal>' 

StageParams (for MinIO/Amazon S3) :
URL =  "s3://<bucket>[/<path>/]" CREDENTIALS = {"AWS_KEY_ID"='<string>', "AWS_SECRET_KEY"='<string>', "AWS_ROLE"='<string>', "AWS_TOKEN"='<string>', "AWS_REGION"='<string>', "COMPRESSION"='<string>', 'PROVIDER'='<string>', 'ENDPOINT'='<string>'}

StageParams (for File System) :
URL= 'file://[/path/]'

StageParams (for sub-stage):
URL= "stage://<stagename>[/path/]"

语法解释

  • IF NOT EXISTS:可选参数,用于在创建 Stage 时检查是否已存在同名的 Stage,避免重复创建。

  • stage_name:要创建的 Stage 的名称。

  • StageParams (for MinIO/Amazon S3):用于指定对象存储为 MinIO 或 S3 的 Stage 的配置参数。

    • URL:指定 S3 存储中的文件路径或目录
    • CREDENTIALS:这是一个 JSON 对象,包含连接到对象存储服务所需的凭证信息。

      • access_key_id:用于身份验证的访问密钥 ID。
      • secret_access_key:与访问密钥 ID 相关联的密钥。
      • aws_role:非必填,如果使用了 IAM 角色,用于指定角色名称。可以在 AWS 上配置角色来分配不同的权限。
      • aws_token:非必填,用于临时访问 AWS 服务的安全令牌。
      • aws_region:指定 Amazon S3 存储所在的 AWS 区域。
      • compression:非必填,指定文件的压缩类型。
      • provider:指定云存储提供商。
      • endpint:指定连接自定义或第三方兼容 S3 API 的服务。
  • StageParams (for File System):用于指定文件系统存储的 Stage 的配置参数。

    • URL:指定文件存储中的文件路径或目录。
  • StageParams (for sub-stage):用于子 Stage 的配置参数。

    • URL:指定文件存储中的文件路径或目录。
  • COMMENT:注释。

示例

#文件系统
mysql> create stage stage_fs url = 'file:///Users/admin/test';

#stage
mysql> create stage sub_stage url = 'stage://fs_stage/test1/';

#s3
mysql>create stage stage01 url = 's3://bucket1/test' credentials = {"aws_key_id"='AKIAYOFAMAB7FM7Axxxx',"aws_secret_key"='UjuSDmekK6uXK6CrUs9YhZzY27VOk9W3qMwYxxxx',"AWS_REGION"='us-west-2','PROVIDER'='Amazon', 'ENDPOINT'='s3.us-west-2.amazonaws.com'};