gpt4 book ai didi

azure - 关于Azure表存储行1MB限制,UTF8代码如何计算?

转载 作者:行者123 更新时间:2023-12-04 01:40:20 25 4
gpt4 key购买 nike

让我们先引用:

Combined size of all of the properties in an entity cannot exceed 1MB. (for a ROW/Entity) from msdn

我的问题是:由于所有内容都是 XML 数据,因此对于 1MB 来说,1MB 是什么,1MB ASCII 字符,还是 1MB UTF8 字符,还是其他什么?

示例:

Row1: PartitionKey="A', RowKey="A", Data="A"
Row2: PartitionKey="A', RowKey="A", Data="A" (this is a UTF8 unicode A)

Row1 和 Row2 大小(长度)相同,还是 Row2.Length=Row1.Length+1

最佳答案

示例中的单列(例如“数据”)仅限于 64 KB 的二进制数据,单行仅限于 1 MB 的数据。字符串以 UTF8 格式编码为二进制,因此限制是字符串最终的字节大小。如果您希望列存储超过 64 KB 的数据,您可以使用 Lokad 提供的 FAT Entity 等技术 ( https://github.com/Lokad/lokad-cloud-storage/blob/master/Source/Lokad.Cloud.Storage/Azure/FatEntity.cs )。该技术非常简单,只需将字符串编码为二进制,然后将二进制拆分为多个列。然后,当您想从表中读取字符串时,只需再次重新连接列并将二进制文件转换回字符串即可。

关于azure - 关于Azure表存储行1MB限制,UTF8代码如何计算?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8950693/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com