我知道如何通过使用NextToken来转发SimpleDB数据。但是,一个人如何准确地处理前几页?我在.NET上,但我认为这并不重要。我对一般策略更感兴趣。
Mike Culver的An Introduction to Amazon SimpleDB网络研讨会提到使用了面包屑,但是他没有在视频中实现它们。
编辑:视频提到了实现向后分页的示例项目,但是视频在显示下载URL之前结束。我发现的一个示例项目与分页无关。
最佳答案
当转到下一页时,您可以仅允许“下一页”而不是任意分页来简化用例。您可以通过使用LIMIT子句在SimpleDB中执行此操作:
SELECT title, summary, votecount FROM posts WHERE userid = '000022656' LIMIT 25
您已经知道如何处理NextToken,但是如果使用此策略,则可以通过存储下一个 token 的痕迹(例如,在Web session 中)并使用先前的NextToken而不是重新发出查询来支持“上一页”随后的一个。
但是,在SimpleDB中处理任意分页的一般情况与上一个和下一个相同。在一般情况下,用户可以点击任意页码,例如5,而无需访问第4或6页。
您可以通过使用NextToken仅要求WHERE子句相同才能正常工作这一事实在SimpleDB中进行处理。因此,您通常可以分两个步骤进行操作,而不是依次查询所有页面以拉下所有中间项目。
因此在伪代码中:
int targetPage, pageSize;
...
int jumpLimit = pageSize * (targetPage - 1);
String query = "SELECT %1 FROM posts WHERE userid = '000022656' LIMIT %2";
String output = "title, summary, votecount";
Result temp = sdb.select(query, "count(*)", jumpLimit);
Result data = sdb.select(query, output, pageSize, temp.getToken());
其中%1和%2是字符串替换,而“sdb.select()”是一个虚构的方法,其中包括String替换代码以及SimpleDB调用。
是否可以通过两次调用SimpleDB(如代码所示)来完成此操作,这取决于WHERE子句的复杂性和数据集的大小。上面的代码得到了简化,因为如果查询花费了5秒钟以上的时间,临时结果可能会返回部分计数。您确实希望将该行循环放入,直到达到正确的计数为止。为了使代码更真实一些,我将其放入方法中并摆脱String替换:
private Result fetchPage(String query, int targetPage)
{
int pageSize = extractLimitValue(query);
int skipLimit = pageSize * (targetPage - 1);
String token = skipAhead(query, skipLimit);
return sdb.select(query, token);
}
private String skipAhead(String query, int skipLimit)
{
String tempQuery = replaceClause(query, "SELECT", "count(*)");
int accumulatedCount = 0;
String token = "";
do {
int tempLimit = skipLimit - accumulatedCount;
tempQuery = replaceClause(tempQuery , "LIMIT", tempLimit + "");
Result tempResult = sdb.select(query, token);
token = tempResult.getToken();
accumulatedCount += tempResult.getCount();
} while (accumulatedCount < skipLimit);
return token;
}
private int extractLimitValue(String query) {...}
private String replaceClause(String query, String clause, String value){...}
这是没有错误处理的一般思想,适用于任意页面(不包括页面1)。
关于c# - 如何使用simpledb进行分页?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/1795245/