我知道如何通过使用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中进行处理。因此,您通常可以分两个步骤进行操作,而不是依次查询所有页面以拉下所有中间项目。
  • 发出查询的限制值是所需页面应从何处开始,并使用SELECT count(*)而不是所需的实际属性。
  • 使用第一步中的NextToken使用所需的属性和页面大小作为LIMIT
  • 来获取实际页面数据

    因此在伪代码中:
    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/

    10-11 22:30
    查看更多