我使用的是Dynamodb。我有一个简单的Employee表,其中包含id、姓名、薪水、美国司法部等字段。什么是dynamodb中select max(salary) from employee的等效查询?
发布于 2016-06-22 15:00:29
您可以对您的模式建模,如下所示:
employee_id,as partition-keysalary,作为表或本地辅助索引的排序关键字。然后,针对给定的employee_id对表执行Query操作,并将ScanIndexForward设置为false,然后选择第一个返回的条目。由于所有一个employee_id的行都以排序的方式存储,因此降序的第一个条目将是具有最高salary的条目。
您也可以将Limit保留为1,在这种情况下,DynamoDB将只返回一条记录。
相关文档here。
发布于 2016-06-22 14:35:44
在Dynamodb中没有廉价的方法来实现这一点。没有内置函数来确定属性的最大值,而无需检索所有项并以编程方式进行计算。
发布于 2016-06-22 14:42:29
不确定boto3,但在boto中可以这样运行
from boto.dynamodb2.table import Table
table = Table("employee")
values = list(table.query_2(reverse=True, limit=1))
MAXVALUE = values[0][salary]https://stackoverflow.com/questions/37959515
复制相似问题