У меня есть таблица DynamoDB под названием Bank-Statements.

Он имеет первичный ключ раздела: -

  • Название: TransactionID (номер)

Он имеет индекс: -

  • Имя: статементатипе-индекс
  • Статус: Активный
  • Тип: ГСИ
  • Ключ раздела: StatementType (строка)

В столбце StatementType есть несколько записей с пометкой «RBS».

Я написал это на C #:

    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?

0
Richard210363 20 Дек 2019 в 19:35

1 ответ

В другом учебнике я нашел этот параметр:

IndexName = "StatementType-index".

Этот код работает:

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
Richard210363 20 Дек 2019 в 20:25
Да, вы должны указать DDB запросить таблицу или определенный индекс. Он не «использует» индексы автоматически, как RDB.
 – 
Charles
20 Дек 2019 в 21:55