带有 ConditionExpression 的 DynamoDb

DynamoDb with ConditionExpression

考虑以下 DynamoDb table:

表名:foo-bar 哈希键:Foo, str 范围键:Bar, str 姓名:Baz, str

现在 vogels API 我正在尝试插入一个带有 HashKey、新 RangeKey 和名称的项目。

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

所以我们为 vogels 定义 table 布局 API:

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

然后插入项目:

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);
        }
});

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

所以我希望系统会给我一个错误,因为 ConditionExpression 已经存在匹配项,但是该项目插入时没有问题。这对 DynamoDb 来说不可能吗?

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

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

您正试图在非键属性上添加唯一约束,目前 DynamoDB 不可能这样做,需要更改架构才能强制执行此约束。