UpdateTableMetadataLocation

更新时间:
复制 MD 格式

调用UpdateTableMetadataLocation接口更新指定表的Metadata文件位置。

注意事项

  • 通过此接口可以将表指向新的metadata文件,实现表schema变更、数据提交等操作。

  • 必须传入当前有效的versionToken进行乐观锁控制,确保并发更新的一致性。

  • versionToken可通过GetTableMetadataLocationGetTable接口获取。

  • 新的metadataLocation必须指向一个有效的Iceberg metadata JSON文件。

权限说明

API

Action

说明

UpdateTableMetadataLocation

oss:UpdateTableMetadataLocation

更新表metadata位置(同时检查Table Policy)

请求语法

PUT /tables/{tableBucketARN}/{namespace}/{name}/metadata-location HTTP/1.1
Content-type: application/json
Host: cn-hangzhou.oss-tables.aliyuncs.com
Date: GMT Date
Authorization: SignatureValue

{
   "versionToken": "string",
   "metadataLocation": "string"
}

请求参数

名称

数据类型

是否必选

示例值

描述

tableBucketARN

字符串

acs:osstables:cn-hangzhou:1234567890:bucket/my-table-bucket

Table BucketARN,格式为acs:osstables:{region}:{uid}:bucket/{bucketName}。位于URI中。

namespace

字符串

my_namespace

表所在的命名空间名称。位于URI中。

name

字符串

my_table

表名称。位于URI中。

versionToken

字符串

aaabbb

当前版本token(乐观锁),可通过GetTableMetadataLocationGetTable接口获取。位于请求体中。

metadataLocation

字符串

oss://data-bucket/metadata/00001-xxx.metadata.json

新的metadata文件OSS路径,必须指向一个有效的Iceberg metadata JSON文件。位于请求体中。

响应参数

名称

数据类型

示例值

描述

metadataLocation

字符串

oss://bucket/metadata/00000-xxx.metadata.json

更新后的metadata文件OSS路径。

name

字符串

my_table

表名称。

namespace

数组

-

表所在的命名空间名称数组。

tableARN

字符串

acs:osstables:cn-hangzhou:1234567890:bucket/my-table-bucket/table/table-id

表的ARN。

versionToken

字符串

abc123def456

更新后的版本token。

示例

请求示例

PUT /tables/acs%3Aosstables%3Acn-hangzhou%3A1234567890%3Abucket%2Fmy-table-bucket/my_namespace/my_table/metadata-location HTTP/1.1
Content-type: application/json
Host: cn-hangzhou.oss-tables.aliyuncs.com
Date: Thu, 10 Apr 2025 08:00:00 GMT
Authorization: OSS4-HMAC-SHA256 Credential=LTAI********************/20250417/cn-hangzhou/osstables/aliyun_v4_request,Signature=a7c3554c729d71929e0b84489addee6b2e8d5cb48595adfc51868c299c0c****

{
   "versionToken": "aaabbb",
   "metadataLocation": "oss://data-bucket/metadata/00001-xxx.metadata.json"
}

返回示例

HTTP/1.1 200 OK
Server: AliyunOSS
x-oss-request-id: 5C06A3B67B8B5A3DA422****
x-oss-server-time: 3
Content-Type: application/json


{
   "metadataLocation": "oss://data-bucket/metadata/00001-xxx.metadata.json",
   "name": "my_table",
   "namespace": ["my_namespace"],
   "tableARN": "acs:osstables:cn-hangzhou:1234567890:bucket/my-table-bucket/table/table_id",
   "versionToken": "cccbbb"
}

SDK

UpdateTableMetadataLocation接口所对应的各语言SDK如下:

命令行工具ossutil

UpdateTableMetadataLocation接口所对应的ossutil命令,请参见update-table-metadata-location

错误码

错误码

HTTP状态码

描述

BadRequestException

400

请求无效或格式错误。

ForbiddenException

403

调用者无权执行此请求。

NotFoundException

404

请求的资源不存在。

ConflictException

409

请求与之前的写入操作存在冲突。