return item with maximum sort-key in dynamodb(在 dynamodb 中返回具有最大排序键的项目)
问题描述
我正在使用 python 脚本访问 AWS 中的 dynamodb 数据库.
I'm using a python script to access a dynamodb database in AWS.
我有一个带有哈希键和排序键的表.
I have a table with a hash key and sort key.
对于给定的哈希键,我想找到具有小于某个值的最大排序键的项目.我该怎么做?
For a given hash key, I want to find the item with the largest sort key that is less than a certain value. How can I do that?
或者,有没有办法从给定的键中找到上一个项目?
Alternatively, is there a way to find the previous item from a given key?
我不是试图找到具有最大属性值的项目(dynamodb中的一项昂贵的任务),我想要最大的键价值.
I am not trying to find the item with the largest attribute value (an expensive task in dynamodb), I want the largest key value.
推荐答案
我找到了答案,
import boto3
import botocore
from boto3.dynamodb.conditions import Key, Attr
dynamodb = boto3.resource('dynamodb')
table = dynamodb.Table(table_name)
response = table.query(
Limit = 1,
ScanIndexForward = False,
KeyConditionExpression=Key('device').eq(device) & Key('epoch').lte(threshold)
)
地点:
- 'device' 是我的哈希键
- 'epoch' 是我的排序键
- threshold 是我要在下面搜索的值
这篇关于在 dynamodb 中返回具有最大排序键的项目的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 dynamodb 中返回具有最大排序键的项目


- 检查具有纬度和经度的地理点是否在 shapefile 中 2022-01-01
- 我如何卸载 PyTorch? 2022-01-01
- YouTube API v3 返回截断的观看记录 2022-01-01
- 如何使用PYSPARK从Spark获得批次行 2022-01-01
- 使用公司代理使Python3.x Slack(松弛客户端) 2022-01-01
- 计算测试数量的Python单元测试 2022-01-01
- 使用 Cython 将 Python 链接到共享库 2022-01-01
- ";find_element_by_name(';name';)";和&QOOT;FIND_ELEMENT(BY NAME,';NAME';)";之间有什么区别? 2022-01-01
- 我如何透明地重定向一个Python导入? 2022-01-01
- CTR 中的 AES 如何用于 Python 和 PyCrypto? 2022-01-01