使用DynamoDBMapper扫描DynamoDB项目

之前,我们介绍了如何使用DynamoDBMapper或底层Java api查询DynamoDB数据库。

除了发出查询之外,DynamoDB还提供扫描功能。
扫描的目的是获取您在DynamoDB表上可能拥有的所有项目。
因此,扫描不需要任何基于我们的分区键或您的全局/本地二级索引的规则。 扫描提供的功能是基于已获取的项目进行过滤,并从已获取的项目中返回特定属性。

下面的代码段通过过滤具有较低日期的项目来对“登录名”表进行扫描。

public List<Login> scanLogins(Long date) {Map<String, String> attributeNames = new HashMap<String, String>();attributeNames.put("#timestamp", "timestamp");Map<String, AttributeValue> attributeValues = new HashMap<String, AttributeValue>();attributeValues.put(":from", new AttributeValue().withN(date.toString()));DynamoDBScanExpression dynamoDBScanExpression = new DynamoDBScanExpression().withFilterExpression("#timestamp < :from").withExpressionAttributeNames(attributeNames).withExpressionAttributeValues(attributeValues);List<Login> logins = dynamoDBMapper.scan(Login.class, dynamoDBScanExpression);return logins;}

DynamoDBMapper的另一个重要功能是并行扫描。 并行扫描将扫描任务划分为多个工作程序,每个逻辑段一个。 工作人员并行处理数据并返回结果。
通常,扫描请求的性能在很大程度上取决于DynamoDB表中存储的项目数。 因此,并行扫描可能会解除扫描请求的某些性能问题,因为您必须处理大量数据。

public List<Login> scanLogins(Long date,Integer workers) {Map<String, String> attributeNames = new HashMap<String, String>();attributeNames.put("#timestamp", "timestamp");Map<String, AttributeValue> attributeValues = new HashMap<String, AttributeValue>();attributeValues.put(":from", new AttributeValue().withN(date.toString()));DynamoDBScanExpression dynamoDBScanExpression = new DynamoDBScanExpression().withFilterExpression("#timestamp < :from").withExpressionAttributeNames(attributeNames).withExpressionAttributeValues(attributeValues);List<Login> logins = dynamoDBMapper.parallelScan(Login.class, dynamoDBScanExpression,workers);return logins;}

在对我们的应用程序使用扫描之前,我们必须考虑到扫描会获取所有表项。 因此,它在费用和性能上都有很高的成本。 此外,它可能会消耗您的配置容量。
通常,最好坚持查询并避免扫描。

您可以在github上找到带有单元测试的完整源代码。

翻译自: https://www.javacodegeeks.com/2016/10/scan-dynamodb-items-dynamodbmapper.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/352367.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vs python生成exe文件_使用VScode编写python程序并打包成.exe文件-文件夹变成exe

1. 下载vscode并安装 2. 配置Python环境 点击左下角的吃了图标&#xff0c;在弹出的菜单中选择extensions&#xff0c;在左上方搜索框内输入“Python”&#xff0c;可以看到好多Python插件&#xff0c;选择安装喜欢的Python插件&#xff08;配图两张&#xff09;。安装Python插…

如何清除主板CMOS

最近很多网友反映&#xff0c;对于清除主板CMOS&#xff0c;不是很了解&#xff0c;操作上也不明白&#xff0c;因此网站重新制作主板CMOS清除的过程&#xff0c;并以图文的形式制作&#xff0c;以便更加直观清楚。 CMOS(本意是指互补金属氧化物半导体存储嚣&#xff0c;是一…

ubuntu如何安装samba

1.samba安装sudo apt-get install samba2.修改smb.confsudo gedit /etc/samba/smb.conf 文件最后增加如下代码&#xff1a;[share] path /home/liunx/share available yes browseable yes public yes writable yes 4.进入home/liunx目录创建share文件夹mkdir /share …

文本处理工具AWK详解

awk简介 awk: 中文意思是报告生成器 能够根据我们输入的信息&#xff0c;将信息格式化以后显示&#xff0c;将定义好的信息以比较美观&#xff08;直观&#xff09;的方式显示出来出现比较早&#xff0c;继而出现了new awk&#xff08;nawk&#xff09;在windows上实现&#x…

安装12G内存读出内存条为3.45G的处理方法

在台式电脑上安装2个内存条&#xff0c;之前是4G的后来加安装了8G内存&#xff0c;本应该有12G但是在电脑上却显示只有3.45G内存为可用&#xff0c; 以下是处理方式&#xff1a; 1、确定两条内存都是可以用 2、在cmd 中输入msconfig 点击enter就可以入系统配置 然后点击引导…

顺序表的介绍与简单运用

1&#xff1a;解释与结构 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构&#xff0c;一般情况下采用数组存 储。在数组上完成数据的增删查改。 顺序表一般可分为一下几类 1.1 静态顺序表 概念&#xff1a;使用定长数组存储元素。注意&#xff1a;这种是…

Fastest way to duplicate mongodb collection

db.myoriginal.aggregate([ { $out: "myCopy" } ]) db.runCommand({aggregate: "myOriginal",pipeline: [{ $match: {} }, { $out: "myCopy" }]});转载于:https://www.cnblogs.com/kevin1988/p/9877551.html

电脑显示链接网络正常但是不能上网,用某些软件会提示系统丢失libeay32.dll

电脑显示链接网络正常但是不能上网&#xff0c;用某些软件会提示系统丢失libeay32.dll,且可以ping通网关 按如下步骤可以重新正常上网&#xff1a; 1.在“开始”菜单找到“运行“ 2.然后在里面输入cmd 按”Enter“键 3.出现的命令提示框内输入“netsh winsock reset"按…

python做算法题优势_Python语言在科学算法中的优势

2019 年第 4 期 信息与电脑 China Computer & Communication 算法语言 Python 语言在科学算法中的优势 刘 瑞 &#xff08;辽宁师范大学海华学院&#xff0c;辽宁 沈阳 110000&#xff09; 摘 要&#xff1a; Python 是一种很有吸引力的语言&#xff0c;是一种面向对象且呈…

Java Spring IOC用法

Java Spring IOC用法 Spring IoC 转载于&#xff1a;http://www.cnblogs.com/flowwind/p/4772375.html在前两篇文章中&#xff0c;我们讲了java web环境搭建 和java web项目搭建,现在看下spring ioc在java中的运用&#xff0c;开发工具为Intellij Idea。 1.简介 IoC(Inversi…

Database学习 - mysql数据类型

MySQL数据类型 可以被分为3类&#xff1a; 1.整型,数值类型 2.日期和时间类型 3.字符串(字符)类型 整型(INT) 数据类型大小M(默认值)范围&#xff08;有符号&#xff09;范围&#xff08;无符号&#xff09;用途tinyint [(M)] [UNSIGNED] [ZEROFILL]1字节4-128~127 (-27~27-1)…

Apache Flink和Kafka入门

介绍 Apache Flink是用于分布式流和批处理数据处理的开源平台。 Flink是具有多个API的流数据流引擎&#xff0c;用于创建面向数据流的应用程序。 Flink应用程序通常使用Apache Kafka进行数据输入和输出。 本文将指导您逐步使用Apache Flink和Kafka。 先决条件 Apache Kafka 0…

matlab集群搭建问题

本文是在matlab 集群搭建中遇到一些问题的总结&#xff1a; 1、破解版的是否可以用&#xff0c;我已经搭建到集群还没使用目前看来破解版的是可以用的&#xff0c;不存在要用到“Licence Manager”。 2、同一个集群中的PC最好是安装同一版本的matlab 和mcde 以防出现不兼容的…

linux下不同服务器间数据传输(rcp,scp,rsync,ftp,sftp,lftp,wget,curl)

因为工作原因&#xff0c;需要经常在不同的服务器见进行文件传输&#xff0c;特别是大文件的传输&#xff0c;因此对linux下不同服务器间数据传输命令和工具进行了研究和总结。主要是rcp,scp,rsync,ftp,sftp,lftp,wget,curl。 rcp rcp不是一种安全的的传输文件的方式&#xff0…

bzoj3143: [Hnoi2013]游走

求经过边的期望次数&#xff0c;然后边的编号相当于给期望一个系数&#xff0c;期望大到小给编号就好 假如可以强行改边为点高斯消元的话是很方便的&#xff0c;然而并不资瓷 但是我们可以先把经过点的期望次数求出来&#xff1a;f(u)sigema((u,v)属于E且v!n)v f(v)/du(v)&…

pythonsqlite3模糊_Python编写通讯录通过数据库存储实现模糊查询功能

1.要求 数据库存储通讯录&#xff0c;要求按姓名/电话号码查询&#xff0c;查询条件只有一个输入入口&#xff0c;自动识别输入的是姓名还是号码&#xff0c;允许模糊查询。 2.实现功能 可通过输入指令进行操作。 &#xff08;1&#xff09;首先输入“add”&#xff0c;可以对通…

分布式Matlab计算集群建立方法与Demo

文章来源&#xff1a;http://hi.baidu.com/modelren/item/6a9d09ff178db405d99e7220 我的实验室有五台双核Pentium D 925计算机&#xff0c;这正适合用来做分布式或并行式计算。我打算只调用那些计算机中的一个核参与计算&#xff0c;留下一个核可以让其他人正常地使用该计算机…

用python实现远程复制 (scp + expect )

scp 功能很强大&#xff0c;但需要人工输入 password, 当然可以通过把 公钥保存在远程主机的 ~/.ssh 目录中&#xff0c;而后就不用输入password&#xff0c;但这需要配置. 用 sshpass 可能在命令输入 password, 但 需要用 “sudo apt-get install sshpass” 安装 如果不想用…

esp8266oled做时钟python_利用esp8266和鸿蒙带的OLED屏做了一个时钟

连接图&#xff1a; 先看原理图&#xff1a;然后接线接线原理如下&#xff1a; * 7pin SPI引脚&#xff0c;正面看&#xff0c;从左到右依次为GND、VCC、D0、D1、RES、DC、CS * ESP8266 --- OLED * 3V --- VCC * G --- GNDS * D7 --- D1 * D5 --- D0 * D2orD8--- CS * D1 --- D…

junit白盒测试 案例_JUnit通过失败测试案例

junit白盒测试 案例为什么要建立一种预期测试失败的机制&#xff1f; 有一段时间&#xff0c;人们会希望并期望JUnit Test案例失败。 尽管这种情况很少见&#xff0c;但确实发生了。 我需要检测JUnit测试何时失败&#xff0c;然后&#xff08;如果期望的话&#xff09;通过而不…