带有ConditionExpression的DynamoDb

Sna*_*ake 3 amazon-web-services amazon-dynamodb

请考虑以下DynamoDb表:

TableName:foo-bar HashKey:Foo, str RangeKey:Bar, str Name:Baz, str

现在有了vogels API,我试图插入一个带有HashKey,一个新的RangeKey和一个Name的项目.

但是对于给定的HashKey,名称不能存在:

所以我们定义了vogels API的表格布局:

var foobar = vogels.define("foo-bar", {
    tableName: "foo-bar",
    hashKey: "foo",
    rangeKey: "bar",
    schema: {
        "foo": Joi.string(),
        "bar": Joi.string(),
        "name": Joi.string()
    }
});
Run Code Online (Sandbox Code Playgroud)

然后插入项目:

var itemToInsert = { foo: "foo", bar: "bar2", name: "TEST" };

var params = {};
params.ConditionExpression = "foo <> :foo AND name <> :name";
params.ExpressionAttributeValues = {
    ":foo": itemToInsert.foo,
    ":name": itemToInsert.name
};

foobar
    .create(itemToInsert, params, function(error, data) {
        if(error) {
            console.log(error);
        }
        else {
            console.log(data);
        }
});
Run Code Online (Sandbox Code Playgroud)

表中已有一个项目具有以下值: {foo: "foo", bar: "bar", name: "TEST" }

所以我期待系统给我一个错误,因为已经有匹配因为ConditionExpression,但是插入的项目没有问题.这对DynamoDb不可能吗?

请注意,无论我是使用vogels还是直接使用aws-sdk,它们都有相同的问题,即插入项目并且ConditionExpression不会阻止插入.

小智 6

DynamoDB插入项目的原因是因为您的表使用了hashkey的复合键:foo,rangekey:bar.您正在尝试插入具有不同键的项目,在本例中为hashkey:foo,rangekey:bar2.在DynamoDB中,插入项时,条件表达式仅针对与完全相同的散列和范围键匹配的现有项进行测试.

您正在尝试在非键属性上添加唯一约束,目前这可能不适用于DynamoDB,并且需要更改架构才能强制执行此约束.