问题描述
我们正在尝试使用其事务哈希检索 qldb 中提交的文档修订。但是在尝试以下查询时它没有返回具有特定哈希的行
SELECT * FROM history(Users) AS h WHERE h.hash='8kmIsF2X2HonQDhuoosBbKZtSQCjHZgnyUmPGZa9pJc='
我相信 qldb 修订版中的 tx 哈希是离子文字,因此不应将其视为字符串。那么我们如何通过哈希检索文档修订版
解决方法
要成功执行此查询,您需要将 hash
值视为 blob 类型 Ion 文字,这可以使用反引号和 {{...}}
来完成:
SELECT * FROM history(Users) AS h WHERE h.hash = `{{8kmIsF2X2HonQDhuoosBbKZtSQCjHZgnyUmPGZa9pJc=}}`
值得注意的是,此查询会扫描 Users
表中所有文档的每个修订版。 QLDB 的
history 不支持索引,这个查询会随着表的增长而降级。