Skip to content

ALTER STAGE

语法说明

ALTER STAGE 用于修改用于修改一个已有的 stage 的属性。

Note

ALTER STAGE 只能一次修改一个参数。因此,如果你需要同时更新多个参数,例如 URLCOMMENT,需要分别执行多次 ALTER STAGE 语句,每次修改一个参数。

语法结构

> ALTER STAGE [ IF EXISTS ] { stage_name } SET
   { StageParams }
   [ COMMENT = '<string_literal>' ]

StageParams (for 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:注释。

示例

create stage stage_fs url = 'file:///Users/admin/test' comment='this is a stage';

mysql> select * from mo_catalog.mo_stages where stage_name='stage_fs';
+----------+------------+--------------------------+-------------------+--------------+---------------------+-----------------+
| stage_id | stage_name | url                      | stage_credentials | stage_status | created_time        | comment         |
+----------+------------+--------------------------+-------------------+--------------+---------------------+-----------------+
|        1 | stage_fs   | file:///Users/admin/test |                   | disabled     | 2024-10-09 03:46:00 | this is a stage |
+----------+------------+--------------------------+-------------------+--------------+---------------------+-----------------+
1 row in set (0.00 sec)

alter stage stage_fs set url = 'file:///Users/admin/test1';
alter stage stage_fs set comment='stage_fs has been changed';

mysql> select * from mo_catalog.mo_stages where stage_name='stage_fs';
+----------+------------+---------------------------+-------------------+--------------+---------------------+---------------------------+
| stage_id | stage_name | url                       | stage_credentials | stage_status | created_time        | comment                   |
+----------+------------+---------------------------+-------------------+--------------+---------------------+---------------------------+
|        1 | stage_fs   | file:///Users/admin/test1 |                   | disabled     | 2024-10-09 03:46:00 | stage_fs has been changed |
+----------+------------+---------------------------+-------------------+--------------+---------------------+---------------------------+
1 row in set (0.00 sec)