以下は、DynamoDB JSONオブジェクトのAWSラムダのnode.jsクエリです。 UserIDはソートキーを持たないプライマリキーです。 GeoHashはインデックス名が "GeoHash-index"のセカンダリキーです。 呼び出しは成功し、エラーは発生しませんが、何も返されません。以下のテストデータはインデックス名に接続していないので間違っている可能性がありますが、AWS/noSQLを初めて使用していて少し失われています。ラムダテストデータがジオハッシュ・ストリングが一致しなければならないAWSラムダクエリ副インデックス
{
"GeoHash": "dpz886gb0tb0",
"Radius": 2,
"Timestamp": 1472601493180,
"UserID": "User1"
}
ある
var AWS = require('aws-sdk');
var docClient = new AWS.DynamoDB({apiVersion: '2012-08-10'});
exports.handler = function(event,context,callback) {
console.log(JSON.stringify(event, null, ' '));
var tableName = "table1";
// getItem
docClient.getItem({
TableName: tableName,
IndexName: "GeoHash-index",
KeyConditionExpression: "GeoHash = :geohash",
ExpressionAttributeValues: {":geohash": "dpz886gb0tb0"}
}),
function(err,data){
if(err){
callback(err);
} else {
callback(null,data);
}
}
};
。思考?
EDIT この方法ではありません成功
var AWS = require('aws-sdk');
var docClient = new AWS.DynamoDB({apiVersion: '2012-08-10'});
exports.handler = function index(event, context, callback) {
var params = {
TableName: "LocationAware1",
IndexName: "GeoHash-index",
KeyConditionExpression: "GeoHash = :geohash",
ExpressionAttributeValues: {
":geohash": {'S': 'dpz886gb0tb0'}
},
};
docClient.query(params, function(err, data) {
if (err)
console.log(JSON.stringify(err));
else
console.log(JSON.stringify(data));
});
}
スティルラムダから "ヌル" 応答を持っている... docClient.getItem({ テーブル名:tableNameの、 キー:{ ユーザーID:{S: "ユーザー2"}、 }}、 この意志しかし、私に値を返す – Iorek