我试图弄清楚AppEngine key name在Java API中的最大长度.
这个问题之前的问题要少得多:
并收到两个相互矛盾的答案(对我来说似乎不太可信的答案……)
@ryan能够在his answer提供相关Python API源代码的链接,我一直在尝试在Java API中找到类似的东西.
但Key.java,KeyFactory.java和KeyTranslator.java似乎都没有对密钥的name属性强制执行任何限制.因此,如果存在限制,则在其他地方实施. KeyTranslator调用com.google.storage.onestore.v3.OnestoreEntity.Path.Element.setName(),它可能是实现限制的地方,但遗憾的是我无法在任何地方找到此类的源代码…
具体来说,我想知道:
> 500字符限制是对后端某处的密钥名称特别强加的硬限制,还是仅仅是一个足以确保完整密钥字符串永远不会超过1500-byte limit of a short text property的建议(具有更多字节的长文本属性无法编入索引) ,如果我理解正确的话).
>如果是硬限制:
>是500个字符还是500个字节(即某些编码后的长度)?
>完整的500字节/字符是否可用于密钥的名称,或者从此编号中扣除其他密钥组件(种类,父级,应用程序ID,…)?
>如果是推荐:
>在所有情况下都足够了吗?
>如果所有密钥都位于我的应用程序的根目录中且类型只有一个字母长,我可以使用的最大值是多少?换句话说:是否有一个公式可以用来计算其他关键组件的实际限制?
>最后,如果我只是尝试通过尝试存储增加长度的密钥来测量此限制,直到我得到一些异常,如果我只创建具有相同祖先路径和相同长度的密钥,我是否能够依赖于我找到的限制在同一个应用中的种类?或者是否有其他可变长度组件可能会被添加并在某些情况下减少可用的键名长度?开发和生产服务器应该相同吗?
解决方法:
数据存储区在后端实现其所有验证(因为它阻止一个客户端中的成功操作在另一个客户端中失败).数据存储区键具有following restrictions:
>一个键最多可以有100个路径元素(这些是类型,名称/ ID对)
>每种类型最多可以包含1500个字节.
>每个名称最多可以包含1500个字节.
500字符限制已转换为1500字节限制.所以你之前看过500个字符限制的地方(如链接问题中@ ryan的回答)现在是1500字节.字符串使用UTF-8编码.
重要的是回答你的问题中的一些细节:
Are the full 500 bytes/characters available for the name of the key or do the other key-components (kind, parent, app-id, …) deduct from this number?
不,每字段限制1500字节.