首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DynamoDB忽略了索引的使用

DynamoDB忽略了索引的使用
EN

Stack Overflow用户
提问于 2019-12-20 16:35:32
回答 1查看 43关注 0票数 0

我有一个叫银行结单的dynamoDB表。

它有一个主分区键:-

  • 名称: TransactionID (号码)

它有一个指数:-

StatementType-index

  • Status: Active

  • 类型: GSI

  • Partition键: StatementType (String)

在StatementType列中有几条标记为"RBS“的记录

我是用C#写的:

代码语言:javascript
复制
    public async Task<string> GetRecordList()
    {
        try
        {
            var request = new QueryRequest
            {
                TableName = "Bank-Statements",
                KeyConditionExpression = "StatementType = :searchKey",
                ExpressionAttributeValues = new Dictionary<string, AttributeValue> {
                    {":searchKey", new AttributeValue { S =  "RBS" }}}
            };

            var response = await dynamoDbClient.QueryAsync(request);  //Error occurs here

            foreach (Dictionary<string, AttributeValue> item in response.Items)
            {
        //do something with item
            }
        }
        catch (Exception e)
        {
            logger.Info("Failed while Getting Record List");
            logger.Info("Error: " + e.Message);
        }

        return "DONE";
    }

我得到了一个错误“查询条件丢失了关键模式元素: TransactionID”

当我使用StatementType索引作为关键时,我为什么要这样做呢?

EN

回答 1

Stack Overflow用户

发布于 2019-12-20 17:25:26

在另一个教程中,我发现了以下设置:

IndexName = "StatementType-index“。

此代码适用于:

代码语言:javascript
复制
public async Task<string> GetRecordList()
{
    try
    {
        var request = new QueryRequest
        {
            TableName = "Bank-Statements",
            IndexName = "StatementType-index",
            KeyConditionExpression = "StatementType = :searchKey",
            ExpressionAttributeValues = new Dictionary<string, AttributeValue> {
                {":searchKey", new AttributeValue { S =  "RBS" }}}
        };

        var response = await dynamoDbClient.QueryAsync(request);  //Error occurs here

        foreach (Dictionary<string, AttributeValue> item in response.Items)
        {
    //do something with item
        }
    }
    catch (Exception e)
    {
        logger.Info("Failed while Getting Record List");
        logger.Info("Error: " + e.Message);
    }

    return "DONE";
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59428599

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档