Как сканировать в DynamoDB на основе значений в массиве? - PullRequest
0 голосов
/ 17 мая 2018

вот мой код, где у меня есть список значений в массиве. Мне нужно получить все проекты из таблицы проектов, которые соответствуют идентификаторам в массиве.

            var arr=[];
            for(var index in data.Items){
                if(data.Items[index].hasOwnProperty('projectId'))
                arr.push(data.Items[index].projectId);
            };

            var params = {
                TableName: 'projects',
                FilterExpression: 'id IN (:id)',
                ExpressionAttributeValues: {
                    ':id': arr
                }

            };

            dynamodbclient.scan(params, function (err, docs) {
                if (err) {
                    console.log("Error", err);
                } else {
                    console.log("Success");
                    callback(err, docs.Items);

                }
            });

Однако я не получаю правильных результатов.

1 Ответ

0 голосов
/ 17 мая 2018

Вариант 1 - Статический: -

Если вам известны все значения, которые он считает заранее, постройте FilterExpression, как указано ниже: -

var params = {
    TableName : "projects",
    FilterExpression : "id IN (:id1, :id2)",
    ExpressionAttributeValues : {
        ":id1" : "id val 1",
        ":id2" : "id val 2"

    }
};

Вариант 2 - Динамический: -

var titleValues = ["The Big New Movie 2012", "The Big New Movie"];
var titleObject = {};
var index = 0;
titleValues.forEach(function(value) {
    index++;
    var titleKey = ":titlevalue"+index;
    titleObject[titleKey.toString()] = value;
});

var params = {
    TableName : "Movies",
    FilterExpression : "title IN ("+Object.keys(titleObject).toString()+ ")",
    ExpressionAttributeValues : titleObject
};

docClient.scan(params, onScan);

function onScan(err, data) {
    if (err) {
        console.error("Unable to scan the table. Error JSON:", JSON.stringify(
                err, null, 2));
    } else {
        // print all the movies
        console.log("Scan succeeded.");
        data.Items.forEach(function(movie) {
            console.log("Item :", JSON.stringify(movie));
        });

        // continue scanning if we have more movies
        if (typeof data.LastEvaluatedKey != "undefined") {
            console.log("Scanning for more...");
            params.ExclusiveStartKey = data.LastEvaluatedKey;
            docClient.scan(params, onScan);
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...